纯css、js 的H5页面对接echarts
做项目时,会遇到一些零碎的技术点。记录下来以防忘记
需求:做可视化界面,但是需要兼容ie8,需要用纯css、js 的H5页面对接echarts,下面为效果图(带定时器循环显示tooltip)。
实现方式(此处为一个中央云南地图的实现方法):
1、定义容器
- // 页面逻辑
<div class="sp-ynsdt" id="main4"></div>
2、声明参数
- var myChart4 = echarts.init(document.getElementById('main4'));
3、配置echarts参数样式
- // 打点函数
- function convertData(data) {
- var res = [];
- for (var i = 0; i < data.length; i++) {
- var geoCoord = geoCoordMap[data[i].name];
- if (geoCoord) {
- res.push({
- name: data[i].name,
- value: geoCoord.concat(0),
- renkou: data[i].renkou,
- mianji: data[i].mianji
- // value: geoCoord.concat(data[i].value)
- });
- }
- }
- return res;
- };
- // 各州市人口面积分布图
- var yunnanoprtion = {
- tooltip: {
- trigger: 'item',
- formatter: function (params) {
- return params.data.name + '人口:' + params.data.renkou + '万人' + '\n' + '面积:' + params.data.mianji + '平方千米';
- }
- },
- title: {
- text: '',
- // subtext: '数据来自网络',
- textStyle: {
- color: '#8B4513',
- fontSize: 20, // 标题字体大小
- right: '50%'
- },
- },
- visualMap: {
- show: false,
- min: 0,
- max: 400,
- left: 20,
- bottom: 10,
- text: ['高', '低'], // 文本,默认为数值文本
- color: ['#87cefa', '#e8f630', '#ff4500'],
- calculable: false
- },
- geo: {
- map: '云南',
- roam: true,
- top: '4%',
- zoom: 1.1,
- roam: false,
- aspectScale: 1,
- label: {
- normal: {
- show: true,
- textStyle: {
- color: 'rgba(0,0,0,0.4)'
- }
- },
- show: false,
- formatter: function (params) {
- return params.data.name + '\n' + '人口:' + params.data.renkou + '人' + '\n' + '面积:' + params.data.mianji +
- ' km²';
- },
- textStyle: {
- top: '-80px',
- color: '#000040', // 地图区域字体颜色
- fontSize: 0.1, // 地图区域字体大小
- opacity: 1, // 地图区域字体透明级别
- backgroundColor: 'rgba(0,23,11,0)' // 地图区域字体背景颜色 rgba(0,23,11,0)
- }
- },
- itemStyle: {
- normal: {
- borderColor: 'rgba(0, 0, 0, 0.2)'
- },
- emphasis: {
- areaColor: null,
- shadowOffsetX: 0,
- shadowOffsetY: 0,
- shadowBlur: 20,
- borderWidth: 0,
- shadowColor: 'rgba(0, 0, 0, 0.5)'
- }
- }
- },
- series: [{
- name: '云南',
- type: 'scatter',
- coordinateSystem: 'geo',
- left: 'center',
- top: 'top',
- map: '云南',
- data: convertData(rawData),
- symbolSize: 10,
- // symbol: 'path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z',
- symbolRotate: 35,
- zoom: 1.3,
- mapLocation: {
- x: 'left'
- },
- // position: ['20%', '60%'],
- // regionHeight: 2,
- top: '4%',
- itemStyle: {
- normal: {
- label: {
- show: false,
- textStyle: {
- color: "#fff",
- fontSize: 9
- }
- }
- },
- emphasis: {
- label: {
- show: true,
- shadowOffsetX: 0,
- shadowOffsetY: 0,
- shadowBlur: 20,
- borderWidth: 0,
- shadowColor: 'rgba(0, 0, 0, 0.5)'
- }
- }
- },
- label: {
- show: true,
- formatter: function (params) {
- return params.data.name + '\n' + '人口:' + params.data.renkou + '人' + '\n' + '面积:' + params.data.mianji +
- ' km²';
- },
- textStyle: {
- top: '-80px',
- color: '#000040', // 地图区域字体颜色
- fontSize: 0.1, // 地图区域字体大小
- opacity: 1, // 地图区域字体透明级别
- backgroundColor: 'rgba(0,23,11,0)' // 地图区域字体背景颜色 rgba(0,23,11,0)
- }
- },
- light: {
- main: {
- color: '#eee9e7', // 光照颜色
- intensity: 1.2, // 光照强度
- shadowQuality: 'high', // 阴影亮度
- shadow: true, // 是否显示阴影
- alpha: 60,
- beta: 10
- },
- ambient: {
- intensity: 0.3
- }
- }
- }, {
- name: 'categoryA',
- type: 'map',
- geoIndex: 0,
- // tooltip: {show: false},
- data: rawData
- }]
- };
4、加载地图
- myChart4.setOption(yunnanoprtion)
定时器循环显示tooltip
- // 必须要设置tooltip
- var index = 0; //播放所在下标
- this.mTime = setInterval(function () {
- myChart4.dispatchAction({
- type: 'showTip',
- seriesIndex: 0,
- dataIndex: index
- });
- index++;
- if (index >= rawData.length) {
- index = 0;
- }
- }, 600);
有不同的观点或者实现方式。欢迎在评论区告诉我。
纯css、js 的H5页面对接echarts的更多相关文章
- 前端视频直播技术总结及video.js在h5页面中的应用
全手打原创,转载请标明出处:https://www.cnblogs.com/dreamsqin/p/12557070.html,多谢,=.=~ (如果对你有帮助的话请帮我点个赞啦) 目前有一个需求是在 ...
- HTML+CSS+JS设计注册页面
HTML实战--设计一个个人信息填写界面 应用的技术:HTML+CSS+JS CSS和JS是套用的模板,主要练习了表单的验证和正则表达式的使用 效果图: 代码: <!DOCTYPE html&g ...
- 小tip:纯CSS让overflow:auto页面滚动条出现时不跳动
本文转载于张鑫旭博客,原文地址:http://www.zhangxinxu.com/wordpress/?p=4552 一.水平居中布局与滚动条跳动的千年难题 当前web届,绝大多数的页面间布局都是水 ...
- 纯CSS让overflow:auto页面滚动条出现时不跳动
现代浏览器滚动条默认是overflow:auto类型的,也就是如果尺寸不足一屏,没有滚动条:超出,出现滚动条.于是,问题来了: 信息流页面,如新浪微博,是从上往下push渲染的.开始只有头部一些信息加 ...
- 纯css+js水平时间轴
自定义,并自动加载时间节点 当前时间节点居中,突出显示 时间动态无痕添加 效果图: 初始状态 时间左走到一定2016.1月后 html: <!-- 水平时间轴 --> <div id ...
- 使用Hammer.js的H5页面开发DOM的一些小说法
前几天,一个小伙伴说叫我帮他写一个移动端上的一个轮播图,个人一般是不接私活的,毕竟平时工作也是单双休,时间也不很多. 可能大部分程序员,多余的时间都是看看新闻,打游戏,或者学习新的知识,缺少运动吧. ...
- 纯css实现图片或者页面变灰色
前言 今天是个沉痛的日子,全国哀悼英雄,各大平台平日鲜丽的界面置纷纷换成了灰色,以表对逝者的安息与尊敬!!对付疫病,我没多大的本事,只能记录一点点知识来提升自己擅长的技术,待到将来能为国家尽一份绵薄之 ...
- Vue使用Clipboard.JS在h5页面中复制内容
安装clipboard.js github路径:https://github.com/zenorocha/clipboard.js 安装: npm install clipboard --save 引 ...
- js,h5页面判断客户端是ios还是安卓
$(function(){ var u = navigator.userAgent, app = navigator.appVersion; var isAndroid = u.indexOf('An ...
随机推荐
- C语言调用VIX_API开关虚拟机
#include <stdio.h> #include <stdlib.h> #include "vix.h" #define USE_WORKSTATIO ...
- python 2.7 - 3.5 升级之路 (二) : 语法与类库升级
背景 在上一篇博文中,我们为升级python 2 -> 3已经做了一些准备.在这篇中,我们将针对语法与类库这两个方面进行讨论. 关于语法 1. print 在python3中, print 已经 ...
- Golang 高效实践之defer、panic、recover实践
前言 我们知道Golang处理异常是用error返回的方式,然后调用方根据error的值走不同的处理逻辑.但是,如果程序触发其他的严重异常,比如说数组越界,程序就要直接崩溃.Golang有没有一种异常 ...
- laravel 5.6初学笔记
laravel 5.6初学笔记 http://note.youdao.com/noteshare?id=bf4b701b49dd035564e7145ba2d978b4 框架简介 laravel文档齐 ...
- Python基础总结之第六天开始【认识List:列表】【认识Tuple:元组】【还有他们基本的操作】(新手可相互督促)
早,在北京的周六,热到不行~~~ 今天更新笔记列表(List).元组(Tuple)以及它们的操作方法 在列表中会经常用到List列表,前面我们认识到的有字符串,字符串数据是不能修改当前字符串里面的任意 ...
- springboot整合mybatis时无法读取xml文件解决方法(必读)
转 http://baijiahao.baidu.com/s?id=1588136004120071836&wfr=spider&for=pc 在springboot整合myba ...
- Java集合 HashSet的原理及常用方法
目录 一. HashSet概述 二. HashSet构造 三. add方法 四. remove方法 五. 遍历 六. 合计合计 先看一下LinkedHashSet 在看一下TreeSet 七. 总结 ...
- 【TensorFlow 3】mnist数据集:与Keras对比
在TF1.8之后Keras被当作为一个内置API:tf.keras. 并且之前的下载语句会报错. mnist = input_data.read_data_sets('MNIST_data',one_ ...
- 温故而知新,重温 Java 7 的那些“新”特性
2009 年 4 月 20 日,Java 的亲生父亲 Sun 被养父 Oracle 以 74 亿美元收购,这在当时可是一件天大的事.有不少同学都担心 Java 的前途,我当时傻不啦叽地也很担心:自己刚 ...
- JS面向对象编程(二):构造函数的继承
对象之间继承的 5 中方法. 比如, 现在有一个"动物"对象的构造函数. function Animal(){ ...