可视化大屏 - 项目1

技术栈

  • 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>

相关推荐

  1. 公司数据展示模板【项目案例-23】

    2024-04-05 10:06:03       29 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-04-05 10:06:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-04-05 10:06:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-04-05 10:06:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-04-05 10:06:03       20 阅读

热门阅读

  1. 循环控制语句的实际应用(2)

    2024-04-05 10:06:03       14 阅读
  2. 安卓APP的开发:为了安全的设计

    2024-04-05 10:06:03       16 阅读
  3. C++11:lambda表达式 & 包装器

    2024-04-05 10:06:03       13 阅读
  4. node.js 常用命令

    2024-04-05 10:06:03       16 阅读
  5. Docker 部署war

    2024-04-05 10:06:03       15 阅读
  6. 解决跨域的几种方法

    2024-04-05 10:06:03       17 阅读
  7. 鸿蒙系统:华为打造的全新智能生态

    2024-04-05 10:06:03       16 阅读