文章目录
- 技术栈
- 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>