可视化大屏 - 项目1

文章目录

  • 技术栈
  • echarts 可视化
  • 需求分析
  • 代码实现

技术栈

  • flexible.js + rem 实现不同终端下的响应式布局,根据不同屏幕宽度,自适配布局;

    • html中引入index.js,可以改名为flexible.js;
    • 默认划分10份,可以自己修改,比如24份,rem = widthPixel / 24 + ‘px’
      在这里插入图片描述
  • vscode 安装cssrem插件,将像素px 转为 rem份额;
    file > preferences > settings 在这里插入图片描述
    也可以点击扩展图标>对应插件的齿轮图表> Extension Settings
    在这里插入图片描述
     
    设置完成,重启vscode,编辑css width 像素时,会自动计算划分的rem数,选择即可,如下:
    在这里插入图片描述
     
    编写一个div块,设置width:80px; height:80px; 检查响应效果;

  • Flex布局;

  • Less ;

  • eCharts 可视化

 

echarts 可视化

  • 百度开源的 js 可视化库,其他还有如D3.js 可视化库;

  • 使用PC端、移动端,兼容主流的浏览器;

  • echarts apache官网; (https://www.echartsjs.com/)

  • echarts快速入门

  • 使用步骤:

    • 下载echarts.js 文件,并在html页面中引用;
    • 准备图表的容器;
    • echarts.init(容器) 初始化实例对象;
    • 指定配置项、数据;
    • 将配置项设置为echarts的实例对象;
  • 基础配置项 ->配置项手册

var option = {
  title: { // 图表的标题
    text: 'Stacked Line'
  },
  tooltip: { // 提示框组件
    trigger: 'axis' //axis坐标轴出发  item 图表触发
  },
  legend: { // 图例
    data: ['Email', 'Union Ads', 'Video Ads', 'Direct', 'Search Engine'] // 图例名称
  },
  grid: { // 坐标网格
    left: '3%', //左边 距离容器距离
    right: '4%', 
    bottom: '3%',
    containLabel: true // 包含刻度
  },
  toolbox: { // 工具箱组件
    feature: {
      saveAsImage: {}
    }
  },
  xAxis: { // x轴
    type: 'category', // 类别
    boundaryGap: false, // 图表与坐标轴的间隙
    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'] // 类别名
  },
  yAxis: { // y轴
    type: 'value' // 显示值
  },
  color: ["red", "black", "pink", "blue", "yellow"], // 每个图形的颜色
  series: [ // 图形数组
    {
      name: 'Email', // 该图表的图例,有name时,legend可以省略
      type: 'line', // 该图表类型
      stack: 'Total', // 不同的图形 数据堆叠
      data: [120, 132, 101, 134, 90, 230, 210] // 该图表的数据
    },
    {
      name: 'Union Ads',
      type: 'line',
      stack: 'Total',
      data: [220, 182, 191, 234, 290, 330, 310]
    },
    {
      name: 'Video Ads',
      type: 'line',
      stack: 'Total',
      data: [150, 232, 201, 154, 190, 330, 410]
    },
    {
      name: 'Direct',
      type: 'line',
      stack: 'Total',
      data: [320, 332, 301, 334, 390, 330, 320]
    },
    {
      name: 'Search Engine',
      type: 'line',
      stack: 'Total',
      data: [820, 932, 901, 934, 1290, 1330, 1320]
    }
  ]
};

 

需求分析

 
在这里插入图片描述

代码实现

index.html

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <link rel="stylesheet" href="css/index.css">
    <title>数据可视化</title>
</head>
<body>
    <script src="js/flexible.js"></script>
    <script src="js/echarts.js"></script>
    <script src="js/index.js"></script>
    <script src="js/jquery.js"></script>
    <!-- css设置body 背景图 -->

    <!-- header 块 -->
    <div class="header">
        <h1>数据可视化</h1>
        <div class="showTime"></div>
    </div>
    <!-- 显示时间的js -->
    <script type="text/javascript">
        // 显示时间的函数
        function freshTime(){
            var date = new Date();
            
            // 块级作用域的变量
            let divShowTime = document.getElementsByClassName("showTime")[0];
            // 解析时间元素
            let curYear = date.getFullYear();
            let curMonth = date.getMonth() + 1; // month从0开始,所以+1
            curMonth = curMonth < 10 ? "0" + curMonth : curMonth;
            let curDate = date.getDate();
            curDate = curDate < 10 ? "0" + curDate : curDate;
            let curHours = date.getHours();
            curHours = curHours < 10 ? "0" + curHours : curHours;
            let curMinutes = date.getMinutes();
            curMinutes = curMinutes < 10 ? "0" + curMinutes : curMinutes;
            let curSeconds = date.getSeconds();
            curSeconds = curSeconds < 10 ? "0" + curSeconds : curSeconds;

            // java 和 javascript 都支持字符串与数值的拼接
            divShowTime.innerHTML = "当前时间:" + curYear + "-" 
            + curMonth + "-" + curDate + " " + curHours 
            + ":" + curMinutes + ":" + curSeconds;
        }
        // 立即执行函数
        (function(){
            // 设置定时器 , 每秒执行一次freshTime函数
            setInterval(freshTime, 1000);
        })()

    </script>


    <!-- 主体部分  -->
    <div class="main">
        <div class="column">
            <!-- 左列 -->
            <div class="commonPanel bar">
                <h2>柱形图</h2>
                <div class="chart"></div>
                <div class="footer"></div>
            </div>
            <div class="commonPanel line">
                <h2 id="leftLine">折线图
                    <a href="javascript:;" class="leftLineTab3">2023</a>
                    <a href="javascript:;" class="leftLineTab4">2024</a>
                </h2>
                <div class="chart"></div>
                <div class="footer"></div>
            </div>
            <div class="commonPanel pie">
                <h2>圆饼图</h2>
                <div class="chart"></div>
                <div class="footer"></div>
            </div>
        </div>

        <div class="column">
            <!-- 中间列 -->
            <div class="num">
                <div class="head">
                    <ul>
                        <li>1230</li>
                        <li>456</li>
                    </ul>
                </div>
                <div class="body">
                    <ul>
                        <li>需求人数</li>
                        <li>供应人数</li>
                    </ul>
                </div>
            </div>
            <div class="map">
                <div class="map1"></div>
                <div class="map2"></div>
                <div class="map3"></div>
                <div class="chart"></div>
            </div>
        </div>

        <div class="column">
            <!-- 右列 -->
            <div class="commonPanel bar">
                <h2>柱形图</h2>
                <div class="chart"></div>
                <div class="footer"></div>
            </div>
            <div class="commonPanel">
                <h2>折线图</h2>
                <div class="chart"></div>
                <div class="footer"></div>
            </div>
            <div class="commonPanel">
                <h2>圆饼图</h2>
                <div class="chart"></div>
                <div class="footer"></div>
            </div>
        </div>
    </div>

    <!-- 展示地图 -->
    <script src="js/china.js"></script>
    <script src="js/myMap.js"></script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/515891.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS 应用开发之TaskPool和Worker的对比 (TaskPool和Worker)

TaskPool&#xff08;任务池&#xff09;和Worker的作用是为应用程序提供一个多线程的运行环境&#xff0c;用于处理耗时的计算任务或其他密集型任务。可以有效地避免这些任务阻塞主线程&#xff0c;从而最大化系统的利用率&#xff0c;降低整体资源消耗&#xff0c;并提高系统…

日期专题:做题笔记 (时间显示/星期计算/星系炸弹/第几天/纪念日)

目录 时间显示 代码 星期计算 代码 星系炸弹 代码 第几天 纪念日 代码 时间显示 时间显示 这道题主要是单位换算。 ①单位换算 ②输出格式&#xff1a; a. 不足两位补前导零。利用printf输出 b. 注意 long long 输出格式应该是 %lld 长整型 代码 #include <…

Day66-企业级防火墙iptables精讲2

Day66-企业级防火墙iptables精讲2 1. iptables项目案例2&#xff1a;局域网共享上网&#xff1a;2. iptables项目案例3&#xff1a;外网IP的端口映射到内网IP的端口3. 老男孩教育iptables项目案例4&#xff1a;IP一对一映射&#xff08;DMZ&#xff09;4. 老男孩教育iptables项…

Java常用类和基础API

文章目录 1. 字符串相关类之不可变字符序列&#xff1a;String1.1 String的特性1.2 String的内存结构1.2.1 概述1.2.2 练习类型1&#xff1a;拼接1.2.3 练习类型2&#xff1a;new1.2.4 练习类型3&#xff1a;intern() 1.3 String的常用API-11.3.1 构造器1.3.2 字符串对象的比较…

【THM】Protocols and Servers(协议和服务器)-初级渗透测试

介绍 这个房间向用户介绍了一些常用的协议,例如: HTTP协议文件传输协议POP3邮件传输协议IMAP每个协议的每个任务都旨在帮助我们了解底层发生的情况,并且通常被优雅的GUI(图形用户界面)隐藏。我们将使用简单的 Telnet 客户端来使用上述协议进行“对话”,以充分了解GUI客户…

Unity开发一个FPS游戏之三

在前面的两篇博客中&#xff0c;我已实现了一个FPS游戏的大部分功能&#xff0c;包括了第一人称的主角运动控制&#xff0c;武器射击以及敌人的智能行为。这里我将继续完善这个游戏&#xff0c;包括以下几个方面&#xff1a; 增加一个真实的游戏场景&#xff0c;模拟一个废弃的…

5.2 通用代码,数组求和,拷贝数组,si配合di翻转数组

5.2 通用代码&#xff0c;数组求和&#xff0c;拷贝数组&#xff0c;si配合di翻转数组 1. 通用代码 通用代码类似于一个用汇编语言写程序的一个框架&#xff0c;也类似于c语言的头文件编写 assume cs:code,ds:data,ss:stack data segmentdata endsstack segmentstack endsco…

刘小光本就疑心赵本山与他媳妇李琳有染,赵本山为证实清白便想起蛋糕上的字,结果呢?

刘小光本就疑心赵本山与他媳妇李琳有染&#xff0c;赵本山为证实清白便想起蛋糕上的字&#xff0c;结果呢&#xff1f; ——小品《生日快乐》&#xff08;中5&#xff09;的台词 &#xff08;接上&#xff09; 赵本山&#xff1a;噢!对对!那谁&#xff0c;老四&#xff0c;是…

GEE错误——土地分类中出现Line 126:composite.select(...).classify is not a function

错误 Line 126:composite.select(...).classify is not a function 出现 "GEE在土地分类中出现的一个问题... is not a function" 的主要原因可能有几种 1. 变量或函数名拼写错误:检查代码中的该函数或变量名是否正确拼写,包括大小写。 2. 函数或变量未声明:检查…

Docker,anaconda环境的部署与迁移

功能上线将提上日程&#xff0c;但是如何将我windows环境下的程序放到linux服务器的测试环境跑通呢&#xff1f;这是我这整个清明假期将要解决的一件事&#xff0c;最蠢的办法就是看自己的环境下有哪些依赖&#xff0c;如何到服务器上一个一个下&#xff0c;但是首先这个方法很…

Brain.js 的力量:构建多样化的人工智能应用程序

机器学习&#xff08;ML&#xff09;是人工智能 (AI) 的一种形式&#xff0c;旨在构建可以从处理的数据中学习或使用数据更好地执行的系统。人工智能是模仿人类智能的系统或机器的总称。 机器学习&#xff08;ML&#xff09;与复杂的数学纠缠在一起&#xff0c;让大多数初学者…

逻辑代数点

文章目录 与或非与非 或非 与或非异或同或布尔恒等式代入定理例子例子 反演定理例子例子:例子: 真值表 与 逻辑式&#xff1a;逻辑式 与 逻辑图最小项例子:最小项编号最小项性质最小项之和 最大项最大项性质最大项编号 逻辑代数的化简公式化简法卡诺图化简法表示逻辑代数用卡诺…

【蓝桥备赛】异或和——树状数组、DFS

题目链接 异或和 思路分析 树上每个点都有一个点权&#xff0c;对树上的更新操作是修改指定点的点权&#xff0c;查询操作是查询指定点为根结点的子树点权异或和。 这里的这些操作都和树状数组的单点修改和区间查询非常相似&#xff0c;即我们在修改一个点时&#xff0c;同时…

Three.js——scene场景、几何体位置旋转缩放、正射投影相机、透视投影相机

个人简介 &#x1f440;个人主页&#xff1a; 前端杂货铺 &#x1f64b;‍♂️学习方向&#xff1a; 主攻前端方向&#xff0c;正逐渐往全干发展 &#x1f4c3;个人状态&#xff1a; 研发工程师&#xff0c;现效力于中国工业软件事业 &#x1f680;人生格言&#xff1a; 积跬步…

医院云HIS系统源码,二级医院、专科医院his系统源码,经扩展后能够应用于医联体/医共体

基于云计算技术的B/S架构的HIS系统&#xff0c;为医疗机构提供标准化的、信息化的、可共享的医疗信息管理系统&#xff0c;实现医患事务管理和临床诊疗管理等标准医疗管理信息系统的功能。 系统利用云计算平台的技术优势&#xff0c;建立统一的云HIS、云病历、云LIS&#xff0…

Linux集群部署项目

目录 一&#xff0c;环境准备 1.1.安装MySQL 1.2.安装JDK 1.3.安装TomCat 1.4.安装Nginx 二&#xff0c;部署 2.1.后台服务部署 2.2.Nginx配置负载均衡及静态资源部署 一&#xff0c;环境准备 1.1.安装MySQL 将MySQL的安装包上传至服务器 查看系统中是否存在mariadb&…

167.乐理基础-四个偏音、六声、七声、清雅燕乐

如果到这五线谱还没记住还不认识的话去看102.五线谱-高音谱号与103.五线谱-低音谱号这两个里&#xff0c;这里面有五线谱对应的音名&#xff0c;对比着看 如果不认识调号去看112.五线谱的调号&#xff08;一&#xff09;、113.五线谱的调号&#xff08;二&#xff09;、114.快…

图片改大小尺寸怎么改?几个修改图片尺寸的方法

日常生活和工作中&#xff0c;图片的大小和尺寸对于我们的工作和生活都至关重要&#xff0c;因此我们经常需要调整图片的大小。我们都知道压缩图是一款功能强大的图片在线处理工具&#xff0c;那么用它怎么调整图片大小呢&#xff1f;下面就让我们一起来看一下具体的操作步骤。…

Sora的阅读技术报告

sora的技术报告 走进sorasora的特性sora的介绍sora的实际操作sora的发展安全措施研究技术 走进sora 大家好&#xff0c;我是清风之上。随着人工智能的发展&#xff0c;慢慢的他已经出现在我们生活中的各个角落&#xff0c;其中有API推出的sora&#xff0c;让我们震惊不已&…

应急响应实战笔记05Linux实战篇(2)

第2篇&#xff1a;捕捉短连接 0x00 前言 ​ 短连接&#xff08;short connnection&#xff09;是相对于长连接而言的概念&#xff0c;指的是在数据传送过程中&#xff0c;只在需要发送数据时&#xff0c;才去建立一个连接&#xff0c;数据发送完成后&#xff0c;则断开此连接…