echarts实现中国地图、鼠标悬浮、点击跳转对应省市、给省市图标、缩放、拖拽、自适应

article/2025/8/18 17:50:36

<template><div><div class="echartsGroup"><!-- 返回中国地图 --><div class="button" v-show="isReturnChina" @click="returnChinaFn()"><img src="../assets/组 29@3x.png" style="width: 18px" alt="" /></div><divref="china_map"id="mapWrap"style="height: 300px; width: 100vw"></div><divstyle="position: absolute; bottom: 15px; margin: 0 8px; display: flex"><el-button-group><el-buttontype="primary"size="small":class="dayIndex == 0 ? 'bg' : 'bg1'"@click="activeHandle(0)">当天</el-button><el-buttontype="primary":class="dayIndex == 1 ? 'bg' : 'bg1'"size="small"@click="activeHandle(1)">近一周</el-button></el-button-group></div></div></div>
</template><script>
import axios from "axios";
import * as echarts from "echarts";
import "echarts/map/js/china.js"; // 核心文件
require("echarts/theme/macarons"); //
import bus from "../js/bus";
const BASE = "http://test.ouyeelf.com/mockapi/107";
export default {data() {return {// data_list: [//   { name: "江苏省", value: 6 },//   { name: "西藏", value: 8 },//   { name: "安徽", value: 118491 },//   { name: "湖北", value: 117036 },//   { name: "湖南", value: 110666 },//   { name: "广东", value: 109915 },//   { name: "浙江", value: 69540 },//   { name: "福建", value: 45146 },//   { name: "山东", value: 42753 },//   { name: "河南", value: 31141 },//   { name: "四川", value: 30287 },//   { name: "河北", value: 29890 },//   { name: "江西", value: 23649 },//   { name: "黑龙江", value: 20475 },//   { name: "陕西", value: 17942 },//   { name: "贵州", value: 16019 },//   { name: "吉林", value: 15441 },//   { name: "广西", value: 11875 },//   { name: "山西省 ", value: 11077 },//   { name: "云南省", value: 9238 },//   { name: "辽宁省", value: 6538 },//   { name: "甘肃省", value: 6128 },//   { name: "重庆市", value: 5883 },//   { name: "内蒙古", value: 5 },//   { name: "海南省", value: 4596 },//   { name: "天津市", value: 4244 },//   { name: "新疆省", value: 4125 },//   { name: "上海市", value: 3429 },//   { name: "宁夏市", value: 3225 },//   { name: "青海市", value: 1833 },//   { name: "北京市", value: 1765 },// ],dayIndex: 0,disPlay:true,peopleCounts: {}, //人数top5DataList: [], //列表展示nameList: "",showProveces: false,mapListData: ["image://","image://","image://",],chinaMap: null,mapChart: null,nameList: "",provinceData: {},toolTipData: [],mapDataList: [//自己做的模拟数据 后续根据业务展示{ name: "辽宁", value: 1 },{ name: "山东", value: 1 },{ name: "上海", value: 1 },{ name: "北京", value: 1 },{ name: "湖北", value: 1 },{ name: "江苏", value: 1 },{ name: "河北", value: 1 },{ name: "重庆", value: 1 },{ name: "云南", value: 1 },{ name: "广东", value: 1 },{ name: "新疆", value: 1 },{ name: "山西", value: 1 },{ name: "安徽", value: 1 },],provinceData: [//省份公司的数据{ name: "深圳市", value: 23, children: ["福田", "南山", "龙华"] },],provinces: {//数据台湾: "taiwan",河北: "hebei",山西: "shanxi",辽宁: "liaoning",吉林: "jilin",黑龙江: "heilongjiang",江苏: "jiangsu",浙江: "zhejiang",安徽: "anhui",福建: "fujian",江西: "jiangxi",山东: "shandong",河南: "henan",湖北: "hubei",湖南: "hunan",广东: "guangdong",海南: "hainan",四川: "sichuan",贵州: "guizhou",云南: "yunnan",陕西: "shanxi1",甘肃: "gansu",青海: "qinghai",新疆: "xinjiang",广西: "guangxi",内蒙古: "neimenggu",宁夏: "ningxia",西藏: "xizang",北京: "beijing",天津: "tianjin",上海: "shanghai",重庆: "chongqing",香港: "xianggang",澳门: "aomen",},isReturnChina: false, //是否显示返回中国地图options: null, //echarts 存数据};},beforeDestroy() {window.removeEventListener("resize", this.screenResize);},mounted() {// 监听屏幕大小变化window.addEventListener("resize", this.screenResize);// 一进来主动调取屏幕适配this.screenResize();window.clickRoute = this.clickRoute;this.$nextTick(() => {this.chinaMaprsult("china");});},methods: {//切换背景颜色activeHandle(e) {this.dayIndex = e;},// 中国地图点击省份 显示当前省份的详细的地区。chinaMapHidden(chinaMap) {let that = this;chinaMap.off("click"); //这里解决多次触发点击事件 但是还会执行2次  引用echarts地图,点击各个省份时,点击一个调用两次接口,再点击一次,调用四次接口,再点击调用八次。。。。依次叠加,问题在于,没有将地图上的点击事件清空chinaMap.on("click", async function (params) {// that.disPlay=false// console.log(params,'params----------------------');bus.$emit("sendByBus", params.name);if (params.name in that.provinces) {let s = await import(`echarts/map/js/province/${that.provinces[params.name]}.js`);if (s) {that.chinaMaprsult(params.name);}}});},// 渲染地图chinaMaprsult(name = null) {var toolTipData = [];//后台接口var that = this;axios({method: "get",url: BASE + "/report/summary",data: {},}).then((res) => {if (res.data.code == "0") {toolTipData = res.data.data.mapData;that.peopleCounts = res.data.data.peopleCount;that.top5DataList = res.data.data.top5Data;bus.$emit("peopleCounts", res.data.data.itemlist);bus.$emit("top5DataList", res.data.data.top5Data);} else {this.$message({type: "error",message: res.data.message,});}},(err) => {console.log(err);});var img ="image://";const chainDataPic = [{adcode: "520321",// people_count_2010: 942904,lat: 41.796767,lng: 123.429096,name: "辽宁",level: "district",parent: "遵义市",},{adcode: "310000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 36.675807,lng: 117.000923,name: "山东",// level: "district",// parent: "遵义市",},{adcode: "310000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 31.222771,lng: 121.490317,name: "上海",// level: "district",// parent: "遵义市",},{adcode: "110000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 39.917544,lng: 116.418757,name: "北京",level: "district",parent: "东城区",},{adcode: "520321",// people_count_2010: 942904,lat: 30.584355,lng: 114.298572,name: "湖北",level: "district",parent: "遵义市",},{adcode: "310000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 31.574729,lng: 120.301663,name: "江苏",// level: "district",// parent: "遵义市",},{adcode: "110000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 38.045474,lng: 114.502461,name: "河北",level: "district",parent: "东城区",},{adcode: "520321",// people_count_2010: 942904,lat: 29.533155,lng: 106.504962,name: "重庆",level: "district",parent: "遵义市",},{adcode: "310000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 25.040609,lng: 102.712251,name: "云南",// level: "district",// parent: "遵义市",},{adcode: "110000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 23.125178,lng: 113.280637,name: "广州",level: "district",parent: "东城区",},{adcode: "520321",// people_count_2010: 942904,lat: 43.792818,lng: 87.617733,name: "新疆",level: "district",parent: "遵义市",},{adcode: "310000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 37.857014,lng: 112.549248,name: "山西",// level: "district",// parent: "遵义市",},{adcode: "110000",// people_count_2010: 523180,// value: [121.490317, 31.222771],lat: 31.86119,lng: 117.283042,name: "安徽",level: "district",parent: "东城区",},];name == "china"? (this.isReturnChina = false): (this.isReturnChina = true);let chinaMap = echarts.init(this.$refs.china_map); //这里是为了获得容器所在位置this.options = {// 鼠标悬浮出现黑框tooltip: {// 鼠标移到图里面的浮动提示框show: true,trigger: "item", //数据项图形触发 //显示悬浮窗口formatter: function (params) {if (typeof params.value[2] == "undefined") {var toolTiphtml = "";for (var i = 0; i < toolTipData.length; i++) {// console.log(params.name == toolTipData[i].name,params.name ,toolTipData[i].name,'params.name == toolTipData[i].name----');if (params.name == toolTipData[i].name) {toolTiphtml += toolTipData[i].name + ":<br>";for (var j = 0; j < toolTipData[i].value.length; j++) {toolTiphtml +=toolTipData[i].value[j].name +":" +toolTipData[i].value[j].value +"<br>";}}}return toolTiphtml;} else {var toolTiphtml = "";for (var i = 0; i < toolTipData.length; i++) {if (params.name == toolTipData[i].name) {toolTiphtml += toolTipData[i].name + ":<br>";for (var j = 0; j < toolTipData[i].value.length; j++) {toolTiphtml +=toolTipData[i].value[j].name +":" +toolTipData[i].value[j].value +"<br>";}}}return toolTiphtml;}},},//数据映射visualMap: {type: "piecewise", //分段标签      type: 'continuous', // 定义为连续型 viusalMapshow: true, //是否显示 visualMap-continuous 组件 如果设置为 false,不会显示,但是数据映射的功能还存在// 指定 visualMapContinuous 组件的允许的最小/大值。min: 0, //最小值// max: 500, //最大值,不设置为无限大left: 8, //距离右侧位置bottom: 55, //距离底部位置orient: "vertical", //组件竖直放置align: "left", //色块在左fontSize: 18,itemWidth: 10, //图形的宽度,即长条的宽度。itemHeight: 18, //图形的宽度,即长条的宽度。// dimension:1,               //指定用数据的『哪个维度』,映射到视觉元素上。『数据』即 series.data。 可以把 series.data 理解成一个二维数组,其中每个列是一个维度,默认取 data 中最后一个维度// seriesIndex:1,             //指定取哪个系列的数据,即哪个系列的 series.data,默认取所有系列seriesIndex: 0, //指定取哪个系列的数据(series.data),若不设置则会影响图上标点颜色设置。hoverLink: true, //鼠标悬浮到 visualMap 组件上时,鼠标位置对应的数值 在 图表中对应的图形元素,会高亮// formatter: function (value) {//   //标签的格式化工具。//   let htmlStr = `//   <div style='font-size:18px;margin-bottom:20px'> ${value.name}</div>//   <p style='text-align:left;margin-top:-10px;'>//        华宝租赁:${localValue}<br/>//        欧冶金服:${perf}<br/>//   </p>// `;//   // 下载速度downloadSpeep:${downloadSpeep}<br/>//   // 可用性usability:${usability}<br/>//   // 监测点数point:${point}<br/>//   return htmlStr;// },realtime: false, // 拖拽时,是否实时更新calculable: true, // 是否显示拖拽用的手柄// 定义 在选中范围中 的视觉元素textGap: 12, //文字主体之间的距离itemSymbol: "circle", //右下角映射组件使用圆点形状showLabel: true,// 是否显示拖拽用的手柄(手柄能拖拽调整选中范围)calculable: true,// 拖拽时,是否实时更新//一以下是分段式视觉映射组件的每一段的范围//gt:大于、gte:大于等于、lt:小于、lte:小于等于。pieces: [{gte: 1,// lte: 5,type: "scatter", // 带有涟漪特效动画的散点(气泡)图label: "打卡定位",color: "#ebf1ff",symbol: img, //自定义的展示图标symbolSize: [12, 20], // (宽高)textStyle: {color: "#35363a", // 页面初始化的地图文字颜色 // 省份标签字体颜色fontSize: 16, // 页面初始化的地图文字大小},itemStyle: {normal: {color: "#4bbbb2",borderColor: "#b4dccd",width: 12,height: 16,},},//定以一个空数组后期点击的时候往里面添加新数据},],},geo: {map: name ? name : "china", // 核心top: "2%",scaleLimit: {min: 1, //最小1倍max: 5, //最大5倍},roam: true, //是否开启鼠标缩放和平移漫游。默认不开启。如果只想要开启缩放或者平移,// 可以设置成 ‘scale’ 或者 ‘move’。设置成 true 为都开启label: {// 页面初始化加载的文字normal: {show: false, // 显示省份标签// formatter: function (params) {//   return mapItemCountArray1//     .map((item) => {//       return item.name == params.name ? item.value[2] + "个" : "";//     })//     .join("");// },textStyle: {// color: '#000'color: "#ccc", // 页面初始化的地图文字颜色 // 省份标签字体颜色fontSize: 10, // // 页面初始化的地图文字大小},},},itemStyle: {//设置样式normal: {label: { show: false },borderWidth: 0.5, //区域边框宽度borderColor: "rgba(119, 156, 255, 1)",areaColor: "#fff", // 区域颜色},emphasis: {// 高亮状态(鼠标移入后)的多边形和标签样式// 移入背景颜色// areaColor: '#ff00ff',areaColor: "#F9D92E", // 区域颜色// shadowOffsetX: 12,// shadowOffsetY: 12,show: true,textStyle: {color: "#000",fontSize: "12px",},},},},// series: [//   //所有的市//   {//     name: "pm2.5",//     type: "effectScatter",//     coordinateSystem: "geo",//     data: convertData(data),//     symbolSize: function(val) {//       return val[2] / 10;//     },//     //这几个样式一定要加,加上才有那种光圈的效果//     showEffectOn: "render",//     rippleEffect: {//       brushType: "stroke"//     },//     hoverAnimation: true,//     label: {//       formatter: "{b}",//       position: "right",//       show: true//     },//     //圆点的样式//     itemStyle: {//       color: "#ddb926"//     },//     emphasis: {//       label: {//         show: true//       }//     }//   }// ],// backgroundColor: "#f7f8fa", // 图表背景色series: [{type: "map",geoIndex: 0,aspectScale: 0.75, //这个参数用于 scale 地图的长宽比。// 最终的 aspect 的计算方式是:geoBoundingRect.width / geoBoundingRect.height * aspectScaleitemStyle: {normal: {backgroundColor: function (params) {// 我这里是用数值value判断,也可用params.name判断if (params.value) {console.log(1111);return "#028090";} else {console.log(2222);return "#eceffe";}},color: function (params) {// 我这里是用数值value判断,也可用params.name判断if (params.value) {console.log(1111);return "#028090";} else {console.log(2222);return "#eceffe";}},// 板块边框颜色borderColor: "rgba(255, 255, 253)",},// zoom: 1.2 // 设置地图默认大小zoom: 1.5, //地图缩放比例,默认为1emphasis: {//是图形在高亮状态下的样式,比如在鼠标悬浮或者图例联动高亮时// label: { show: true },//是图形在默认状态下的样式label: {show: true, //是否显示标签textStyle: {color: "black",},},},},label: {normal: {show: true, //显示省份标签textStyle: { color: "#696969" }, //省份标签字体颜色},emphasis: {show: true,textStyle: {},},},data: this.mapDataList,},// 用于地图中给每个名字设置前面的图标...chainDataPic.map((item, index) => {return {type: "scatter",coordinateSystem: "geo",//自定义图片的 位置(lng, lat)data: [{ name: item.name, value: [item.lng, item.lat] }],//自定义图片的 大小symbolSize: [12, 18],//自定义图片的 路径symbol: this.mapListData[index],// symbolKeepAspect: "true",symbol: this.disPlay==true?img:'',itemStyle: {normal: {color: "#4bbbb2",borderColor: "#b4dccd",width: 12,height: 16,},},};}),// {//   type: "effectScatter",//   coordinateSystem: "geo",//   rippleEffect: {//     brushType: "fill",//     scale: 0,//   },//   showEffectOn: "render",//   label: {//     lineHeight: 30,//     normal: {//       show: true,//       color: "#081727",//       position: "inside",//       padding: [5, 0, 0, 0],//       verticalAlign: "middle",//       formatter: function (para) {//         return "{cnNum|" + para.data.value[2] + "}";//       },//       rich: {//         cnNum: {//           fontSize: 16,//           color: "#081727",//           lineHeight: 28,//         },//       },//     },//   },//   symbol: "roundRect",//   // symbolRotate: 20,//   symbolSize: [40, 28],//   data: [],//   zlevel: 1,// },],};chinaMap.setOption(this.options);this.chinaMapHidden(chinaMap);},// 返回中国地图returnChinaFn() {bus.$emit("sendMessage", this, this.showProveces);this.chinaMaprsult("china");},// 点击跳转页面clickRoute() {alert("点击了,做其他操作!");// this.$router.push('/')},// 获取散点图数据,然后渲染在地图上// getData() {//   let seriesArr = this.scatterData.map((item) => {//     this.nameList = item.name;//     return {//       name: item.name,//       type: "effectScatter", // 带有涟漪特效动画的散点(气泡)图//       data: item.children,//       coordinateSystem: "geo", // 让散点图和地图关联起来,就是渲染在地图上//       rippleEffect: {//         number: 3, // 波纹的数量//         scale: 5, // 波纹的最大缩放比例//       },//     };//   });//   let dataOption = {//     series: seriesArr, // 散点数据//   };//   // 生成图表//   let chinaMap = echarts.init(this.$refs.china_map); //这里是为了获得容器所在位置//   chinaMap.setOption(dataOption);// },// 监听屏幕变化screenResize() {this.$nextTick(() => {// 获取图表区域的宽度,作为基准值来设置其他需要动态改变的尺寸let width = this.$refs.china_map.offsetWidth;this.size = (width / 100) * 3.6; // 定义一个基准尺寸// 拆分option:3、受屏幕大小影响的配置在屏幕改变的时候setlet screenOption = {// 图例大小legend: {itemWidth: this.size / 2,itemHeight: this.size / 2,},//  标题大小通过动态style来控制title: {textStyle: {fontSize: this.size,},},};let chinaMap = echarts.init(this.$refs.china_map);chinaMap.setOption(screenOption);// 更新图表chinaMap.resize();});},// 双击地图回到中国地图back() {let backOption = {geo: {map: "china", // geo中map设置为谁就会显示那个地图},};let chinaMap = echarts.init(this.$refs.china_map);chinaMap.setOption(backOption);},},
};
</script><style scoped>
.echartsGroup {/* height: 400px; *//* height: 100vh; *//* width: 500px;height: 500px; */position: relative;
}
.echartsGroup .button {width: 100px;height: 40px;line-height: 40px;text-align: center;/* border: 1px solid #eceffe; *//* border-radius: 10px; */cursor: pointer;position: absolute;top: 0px;left: 0px;z-index: 99;
}
.bg1 {border-radius: 4px;text-align: center;border: 1px solid #babad3;color: rgb(152, 163, 212);background: #fff;
}.bg {border-radius: 4px;border: 1px solid #babad3;text-align: center;color: rgb(255, 255, 255);background: rgb(152, 163, 212);
}
::v-deep .el-button--primary:focus,
.el-button--primary:hover {background: rgb(152, 163, 212);border-color: 1px solid #babad3;color: rgb(255, 255, 255);
}
</style>  <style>
.list-ul {list-style: none;
}
.list-li {pointer-events: all;cursor: pointer;
}
</style>
<template><div><div @click="goBack()">返回</div><div :id="id" class="o-echarts"></div></div>
</template><script>
export default {name: 'province',data () {return {id: 'echarts_' + new Date().getTime() + Math.floor(Math.random() * 1000),echartObj: null,option: {title: {text: '',top: '8%',left: '8%',textStyle: {fontSize: 14,fontWeight: 300,color: '#b6d7ff'}},tooltip: {padding: 0,//   backgroundColor: "transparent",// 数据格式化formatter: function (params, callback) {return params.name + ':' + params.value}},legend: {orient: 'vertical',top: '9%',left: '5%',icon: 'circle',data: [],selectedMode: 'single',selected: {},itemWidth: 12,itemHeight: 12,itemGap: 30,inactiveColor: '#b6d7ff',textStyle: {color: '#ec808d',fontSize: 14,fontWeight: 300,padding: [0, 0, 0, 15]}},visualMap: {min: 0,max: 500,left: 'left',top: 'bottom',text: ['高', '低'], // 取值范围的文字inRange: {color: ['#e0ffff', 'blue'] // 取值范围的颜色},show: true // 图注},geo: {map: '',roam: false, // 不开启缩放和平移zoom: 0.6, // 视角缩放比例label: {normal: {show: true,fontSize: 10,color: '#000'},emphasis: {show: true,color: 'blue',}},itemStyle: {normal: {borderColor: 'rgba(0, 0, 0, 0.2)'},emphasis: {areaColor: 'skyblue', // 鼠标选择区域颜色shadowOffsetX: 0,shadowOffsetY: 0,shadowBlur: 20,borderWidth: 0,shadowColor: 'rgba(0, 0, 0, 0.5)'}},left: '5%',right: '5%',top: '5%',bottom: '5%'},series: [{name: '年度总项目数据查询',type: 'map',geoIndex: 0, // 不可缺少,否则无tooltip 指示效果data: []}],provinceJSON: {},provinceName: ''}}},mounted () {const provinceName = this.$route.query.provinceNameconst province = this.$route.query.provincethis.provinceName = provinceNamethis.provinceJSON = require('../../utils/省份数据/json(省份)/' + provinceName)this.option.geo.map = provincethis.echartObj = echarts.init(document.getElementById(this.id))echarts.registerMap(province, this.provinceJSON)this.echartObj.setOption(this.option);window.addEventListener('resize', () => {if (this.echartObj && this.echartObj.resize) {this.echartObj.resize()}})},methods: {goBack () {this.$router.go(-1)},}
}
</script>
<style lang="scss">
.o-echarts {height: 400px;width: 600px;margin: auto;
}
</style>

引入echarts

npm下载

1

npm installecharts

cdn引入

1

2

3

4

<script

type="text/javascript"

src="https://cdn.jsdelivr.net/npm/echarts/dist/echarts.min.js"

></script>

引入中国地图china.js

1

2

3

4

<script

type="text/javascript"

src="https://cdn.jsdelivr.net/npm/echarts/map/js/china.js"

></script>

配置中国地图

定义一个div来作为地图的载体

1

2

3

4

5

6

7

8

9

10

11

12

render: function(createElement) {

returncreateElement("div", {

attrs: {

id: "main",

},

style: {

height: "450px",

width:'600px',

margin: 'auto'

},

});

},

设置各省份的值

定义省份数据

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

data() {

return{

dataList: [

{ name: "南海诸岛"},

{ ename: "beijing", name: "北京"},

{ ename: "tianjin", name: "天津"},

{ ename: "shanghai", name: "上海"},

{ ename: "chongqing", name: "重庆"},

{ ename: "hebei", name: "河北"},

{ ename: "henan", name: "河南"},

{ ename: "yunnan", name: "云南"},

{ ename: "liaoning", name: "辽宁"},

{ ename: "heilongjiang", name: "黑龙江"},

{ ename: "hunan", name: "湖南"},

{ ename: "anhui", name: "安徽"},

{ ename: "shandong", name: "山东"},

{ ename: "xinjiang", name: "新疆"},

{ ename: "jiangsu", name: "江苏"},

{ ename: "zhejiang", name: "浙江"},

{ ename: "jiangxi", name: "江西"},

{ ename: "hubei", name: "湖北"},

{ ename: "guangxi", name: "广西"},

{ ename: "gansu", name: "甘肃"},

{ ename: "shanxi", name: "山西"},

{ ename: "neimenggu", name: "内蒙古"},

{ ename: "shanxi1", name: "陕西"},

{ ename: "jilin", name: "吉林"},

{ ename: "fujian", name: "福建"},

{ ename: "guizhou", name: "贵州"},

{ ename: "guangdong", name: "广东"},

{ ename: "qinghai", name: "青海"},

{ ename: "xizang", name: "西藏"},

{ ename: "sichuan", name: "四川"},

{ ename: "ningxia", name: "宁夏"},

{ ename: "hainan", name: "海南"},

{ name: "台湾"},

{ ename: "xianggang", name: "香港"},

{ ename: "aomen", name: "澳门"},

],

};

},

随机给各省份赋值

1

2

3

4

let dataList = this.dataList;

for(let i = 0; i < dataList.length; i++){

dataList[i].value = Math.ceil(Math.random() * 1000 - 1);

}

鼠标悬浮展示

option中的tooltip可以设置鼠标悬浮在省份上的数据显示

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

// 鼠标悬浮提示框

series: [

{

name: "省份",

type: "map",

geoIndex: 0,

data: this.dataList,

},

],

tooltip: {

//数据格式化

formatter: function(params, callback) {

return(

params.seriesName + "<br />"+ params.name + ":"+ params.value

);

},

},

如下图为鼠标悬浮在广东上的数据提示👇

visualMap图注配置数值映射

在min和max中,数值越大,区域颜色越深。

1

2

3

4

5

6

7

8

9

10

11

visualMap: {

min: 0, //最小值

max: 1000, //最大值

left: "left", //位于地图左边

top: "bottom",//位于地图下方

text: ["高", "低"], //取值范围的文字

inRange: {

color: ["#e0ffff", "blue"], //取值范围的颜色

},

show: true, //图注

},

geo地图绘制

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

geo: {

map: "china", //引入地图数据

roam: false, //不开启缩放和平移

zoom: 1, //视角缩放比例

label: {

normal: {

show: true,

fontSize: "10",

color: "rgba(0,0,0,0.7)",

},

},

itemStyle: {

normal: {

borderColor: "rgba(0, 0, 0, 0.2)",

},

emphasis: { //高亮的显示设置

areaColor: "skyblue", //鼠标选择区域颜色

shadowOffsetX: 0,

shadowOffsetY: 0,

shadowBlur: 20,

borderWidth: 0,

shadowColor: "rgba(0, 0, 0, 0.5)",

},

},

},

省份区域点击事件

可以通过该点击事件实现省份下钻联动,点击跳转到省级地图页面,省级地图页面根据传入参数渲染不同的省份地图数据即可,具体实现后面会讲到。

1

2

3

4

5

6

7

8

9

10

myChart.on("click", function(params) {

if(!params.data.ename){

alert('暂无'+ params.name + '地图数据');

return;

}

_this.$router.push({

path: "/province",

query: { provinceName: params.data.ename, province: params.name },

});

});

完整代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

<script>

export default{

render: function(createElement) {

returncreateElement("div", {

attrs: {

id: "main",

},

style: {

height: "450px",

width:'600px',

margin: 'auto'

},

});

},

data() {

return{

dataList: [

{ name: "南海诸岛"},

{ ename: "beijing", name: "北京"},

{ ename: "tianjin", name: "天津"},

{ ename: "shanghai", name: "上海"},

{ ename: "chongqing", name: "重庆"},

{ ename: "hebei", name: "河北"},

{ ename: "henan", name: "河南"},

{ ename: "yunnan", name: "云南"},

{ ename: "liaoning", name: "辽宁"},

{ ename: "heilongjiang", name: "黑龙江"},

{ ename: "hunan", name: "湖南"},

{ ename: "anhui", name: "安徽"},

{ ename: "shandong", name: "山东"},

{ ename: "xinjiang", name: "新疆"},

{ ename: "jiangsu", name: "江苏"},

{ ename: "zhejiang", name: "浙江"},

{ ename: "jiangxi", name: "江西"},

{ ename: "hubei", name: "湖北"},

{ ename: "guangxi", name: "广西"},

{ ename: "gansu", name: "甘肃"},

{ ename: "shanxi", name: "山西"},

{ ename: "neimenggu", name: "内蒙古"},

{ ename: "shanxi1", name: "陕西"},

{ ename: "jilin", name: "吉林"},

{ ename: "fujian", name: "福建"},

{ ename: "guizhou", name: "贵州"},

{ ename: "guangdong", name: "广东"},

{ ename: "qinghai", name: "青海"},

{ ename: "xizang", name: "西藏"},

{ ename: "sichuan", name: "四川"},

{ ename: "ningxia", name: "宁夏"},

{ ename: "hainan", name: "海南"},

{ name: "台湾"},

{ ename: "xianggang", name: "香港"},

{ ename: "aomen", name: "澳门"},

],

};

},

methods: {

initEchart() {

let dataList = this.dataList;

for(let i = 0; i < dataList.length; i++){

dataList[i].value = Math.ceil(Math.random() * 1000 - 1);

}

const _this = this;

varmyChart = echarts.init(document.getElementById("main"));

varoption = {

tooltip: {

//数据格式化

formatter: function(params, callback) {

return(

params.seriesName + "<br />"+ params.name + ":"+ params.value

);

},

},

visualMap: {

min: 0,

max: 1000,

left: "left",

top: "bottom",

text: ["高", "低"], //取值范围的文字

inRange: {

color: ["#e0ffff", "blue"], //取值范围的颜色

},

show: true, //图注

},

geo: {

map: "china", //引入地图数据

roam: false, //不开启缩放和平移

zoom: 1, //视角缩放比例

label: {

normal: {

show: true,

fontSize: "10",

color: "rgba(0,0,0,0.7)",

},

},

itemStyle: {

normal: {

borderColor: "rgba(0, 0, 0, 0.2)",

},

emphasis: { //高亮的显示设置

areaColor: "skyblue", //鼠标选择区域颜色

shadowOffsetX: 0,

shadowOffsetY: 0,

shadowBlur: 20,

borderWidth: 0,

shadowColor: "rgba(0, 0, 0, 0.5)",

},

},

},

// 鼠标悬浮提示框

series: [

{

name: "省份",

type: "map",

geoIndex: 0,

data: this.dataList,

},

],

};

myChart.setOption(option);

myChart.on("click", function(params) {

if(!params.data.ename){

alert('暂无'+ params.name + '地图数据');

return;

}

_this.$router.push({

path: "/province",

query: { provinceName: params.data.ename, province: params.name },

});

});

},

},

mounted() {

this.initEchart();

},

};

</script>

展示效果

配置省级地图

前面通过中国地图的省份区域点击事件跳转到省级地图页面,并传递对应参数,在省级地图页面可以根据参入参数来渲染不同的地图数据。

引入省份地图资源

如下图,省份地图资源的js版数据和json版数据我都已经放在源码中,这里我使用的是json版数据,有需要的同学可以直接去下载。

编写简单页面

返回按钮+省级地图。

1

2

3

4

<div>

<div@click="goBack()">返回</div>

<div:id="id"class="o-echarts"></div>

</div>

地图配置

与前面中国地图的配置规则是一样的,按需配置即可

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

option: {

title: {

text: '',

top: '8%',

left: '8%',

textStyle: {

fontSize: 14,

fontWeight: 300,

color: '#b6d7ff'

}

},

tooltip: {

padding: 0,

// 数据格式化

formatter: function(params, callback) {

returnparams.name + ':'+ params.value

}

},

legend: {

orient: 'vertical',

top: '9%',

left: '5%',

icon: 'circle',

data: [],

selectedMode: 'single',

selected: {},

itemWidth: 12,

itemHeight: 12,

itemGap: 30,

inactiveColor: '#b6d7ff',

textStyle: {

color: '#ec808d',

fontSize: 14,

fontWeight: 300,

padding: [0, 0, 0, 15]

}

},

visualMap: {

min: 0,

max: 500,

left: 'left',

top: 'bottom',

text: ['高', '低'], // 取值范围的文字

inRange: {

color: ['#e0ffff', 'blue'] // 取值范围的颜色

},

show: true// 图注

},

geo: {

map: '',

roam: false, // 不开启缩放和平移

zoom: 0.6, // 视角缩放比例

label: {

normal: {

show: true,

fontSize: 10,

color: '#000'

},

emphasis: {

show: true,

color: 'blue',

}

},

itemStyle: {

normal: {

borderColor: 'rgba(0, 0, 0, 0.2)'

},

emphasis: {

areaColor: 'skyblue', // 鼠标选择区域颜色

shadowOffsetX: 0,

shadowOffsetY: 0,

shadowBlur: 20,

borderWidth: 0,

shadowColor: 'rgba(0, 0, 0, 0.5)'

}

},

left: '5%',

right: '5%',

top: '5%',

bottom: '5%'

},

series: [

{

name: '年度总项目数据查询',

type: 'map',

geoIndex: 0, // 不可缺少,否则无tooltip 指示效果

data: []

}

],

provinceJSON: {},

provinceName: ''

}

根据参数配置不同地图数据

1

2

3

4

5

6

7

8

9

10

11

12

13

const provinceName = this.$route.query.provinceName

const province = this.$route.query.province

this.provinceName = provinceName

this.provinceJSON = require('../../utils/省份数据/json(省份)/'+ provinceName)

this.option.geo.map = province

this.echartObj = echarts.init(document.getElementById(this.id))

echarts.registerMap(province, this.provinceJSON)

this.echartObj.setOption(this.option);

window.addEventListener('resize', () => {

if(this.echartObj && this.echartObj.resize) {

this.echartObj.resize()

}

})

完整代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

101

102

103

104

105

106

107

108

109

110

111

112

113

114

115

116

117

118

119

120

121

122

123

124

125

126

127

128

129

130

131

132

133

134

135

136

137

138

<template>

<div>

<div@click="goBack()">返回</div>

<div:id="id"class="o-echarts"></div>

</div>

</template>

<script>

export default {

name: 'province',

data () {

return {

id: 'echarts_' + new Date().getTime() + Math.floor(Math.random() * 1000),

echartObj: null,

option: {

title: {

text: '',

top: '8%',

left: '8%',

textStyle: {

fontSize: 14,

fontWeight: 300,

color: '#b6d7ff'

}

},

tooltip: {

padding: 0,

// backgroundColor: "transparent",

// 数据格式化

formatter: function (params, callback) {

return params.name + ':' + params.value

}

},

legend: {

orient: 'vertical',

top: '9%',

left: '5%',

icon: 'circle',

data: [],

selectedMode: 'single',

selected: {},

itemWidth: 12,

itemHeight: 12,

itemGap: 30,

inactiveColor: '#b6d7ff',

textStyle: {

color: '#ec808d',

fontSize: 14,

fontWeight: 300,

padding: [0, 0, 0, 15]

}

},

visualMap: {

min: 0,

max: 500,

left: 'left',

top: 'bottom',

text: ['高', '低'], // 取值范围的文字

inRange: {

color: ['#e0ffff', 'blue'] // 取值范围的颜色

},

show: true // 图注

},

geo: {

map: '',

roam: false, // 不开启缩放和平移

zoom: 0.6, // 视角缩放比例

label: {

normal: {

show: true,

fontSize: 10,

color: '#000'

},

emphasis: {

show: true,

color: 'blue',

}

},

itemStyle: {

normal: {

borderColor: 'rgba(0, 0, 0, 0.2)'

},

emphasis: {

areaColor: 'skyblue', // 鼠标选择区域颜色

shadowOffsetX: 0,

shadowOffsetY: 0,

shadowBlur: 20,

borderWidth: 0,

shadowColor: 'rgba(0, 0, 0, 0.5)'

}

},

left: '5%',

right: '5%',

top: '5%',

bottom: '5%'

},

series: [

{

name: '年度总项目数据查询',

type: 'map',

geoIndex: 0, // 不可缺少,否则无tooltip 指示效果

data: []

}

],

provinceJSON: {},

provinceName: ''

}

}

},

mounted () {

const provinceName = this.$route.query.provinceName

const province = this.$route.query.province

this.provinceName = provinceName

this.provinceJSON = require('../../utils/省份数据/json(省份)/' + provinceName)

this.option.geo.map = province

this.echartObj = echarts.init(document.getElementById(this.id))

echarts.registerMap(province, this.provinceJSON)

this.echartObj.setOption(this.option);

window.addEventListener('resize', () => {

if (this.echartObj && this.echartObj.resize) {

this.echartObj.resize()

}

})

},

methods: {

goBack () {

this.$router.go(-1)

},

}

}

</script>

<stylelang="scss">

.o-echarts {

height: 400px;

width: 600px;

margin: auto;

}

</style>


http://chatgpt.dhexx.cn/article/XWcSRVkw.shtml

相关文章

爬虫案例:中国高校排名(2021.1.3可爬代码)

案例来源&#xff1a;北京理工大学网络课程《python网络爬虫与信息获取》 在实际上手操作中&#xff0c;发现视频中演示的代码无法完整运行&#xff0c;经个人探索后&#xff0c;记录如下 首先附上课程演示中提供的代码&#xff1a; import requests from bs4 import Beautifu…

中国传统节日春节网页HTML代码 学生网页课程设计期末作业下载 春节大学生网页设计制作成品下载 DW春节节日网页作业代码下载

传统节日春节网页作品 网页内容知识点应用效果描述网页预览网页下载 网页内容 中国传统节日——大学生春节网页设计作品采用DIV CSS布局制作&#xff0c;共6个页面&#xff0c;网页内容主要覆盖&#xff1a;春节简介、节日起源、传统习俗、民族特色、社会效应、国际影响。 知…

java怎么跳转到某一行_java中如何跳转到指定位置?

java中如何跳转到指定位置? yhn80597 LV11 2013-06-20 我的意思是能不能使用什么语句跳转到任意指定的位置?不一定是只跳出循环,比如我下面写了2个类,能不能在一个类中使用跳转语句跳转到另一个类中的指定位置继续执行?下面是我的例子。。。。package com.cq;import java…

AndroidStudio登录注册界面跳转

这里写目录标题 1.登录界面编写1.1顶部图片1.2账号提示输入框1.3密码提示输入框1.4记住密码自动登录插图1.5登录按钮1.6 还没有账号提示1.7加一些文本信息 2.注册页面编写3.界面跳转 1.登录界面编写 新建module-生成MainActivity Java文件和activity_main XML文件 在XML文件中…

恶意代码分析实战

安全技术大系 恶意代码分析实战&#xff08;最权威的恶意代码分析指南&#xff0c;理论实践分析并重&#xff0c;业内人手一册的宝典&#xff09; 【美】Michael Sikorski&#xff08;迈克尔.斯科尔斯基&#xff09;, Andrew Honig&#xff08;安德鲁.哈尼克&#xff09;著 …

echarts,map中国地图点击各省,跳转展示,从省返回到中国地图【china.js】

效果图&#xff1a; 1.点击省&#xff0c;跳转到河北省 2.返回&#xff0c;从省返回到中国地图 话不多说&#xff0c;直接上代码&#xff0c;1.复制粘贴&#xff0c;2.在引入对应js即可 注&#xff1a;全部各省地图&#xff0c;下载地址&#xff1a;** <!DOCTYPE html>…

利用pyecharts实现中国省与市之间的跳转

利用pyecharts实现中国省与市之间的跳转 需求需要的包参考正文读取excel中的数据生成全国地图生成各省份地图将全国地图与各省市地图相互链接 需求 地图上显示中国各省份名称及相对应的数据&#xff08;存于excel中&#xff0c;数据可自己定义读取&#xff09;&#xff0c;随鼠…

html弹跳qq群号代码,抖音上QQ群霸屏消息代码分享_抖音上QQ群霸屏消息代码大全-街机中国...

今天抖音上很多人拍摄在QQ中发送代码&#xff0c;可以让表情霸屏的视频。小编的QQ群也收到了很多霸屏贴表情消息。 首先 复制代码&#xff1a;sticker_start_tag_for_text{"originMsgType":0,"x":0.07037036865949631,"y":0.97685185223817825,&…

微信小程序点击跳转页面

第一步&#xff1a;index.wxml <button bindtap"gotoPage" style"color: rgb(151, 27, 27);">详情页面</button> 第二步&#xff1a;index.js // 详情页面跳转页面gotoPage: function (options) {wx.navigateTo({url: /pages/xiang/xiang,…

中国地图实现点击某省市区域跳转到相应页面

源码下载见页底 <!DOCTYPE html> <html><head><meta charset="utf-8"><title>中国地图-点见省市区域页面跳转</title></head><body><style>#main{background-color: #B1D0EC;width: 600px; height: 600px; ma…

java的html跳转,java跳转html并传值

java跳转html并传值 [2021-01-30 05:39:20] 简介: php去除nbsp的方法:首先创建一个PHP代码示例文件;然后通过“preg_replace("/(\s|\&nbsp\;| |\xc2\xa0)/", " ", strip_tags($val));”方法去除所有nbsp即可。推荐:《PHP视频教 php实现跳转传值的…

java jmap_Java常用分析工具之jmap

简介 jmap是JDK中提供的一个用来监视进程运行中的jvm物理内存的占用情况的工具。该进程内存内&#xff0c;所有对象的情况&#xff0c;例如产生了哪些对象&#xff0c;对象数量。当系统崩溃时&#xff0c;jmap 可以从core文件或进程中获得内存的具体匹配情况&#xff0c;包括He…

JVM工具之jmap命令使用

写在前面 该命令可用于查看虚拟机中对象实例数以及占用空间大小&#xff0c;生成堆转储文件&#xff0c;之后结合jvirsualvm等工具进行可视化查看&#xff0c;辅助定位程序的内存异常问题。 测试代码 public class ManyObj {private static List<People> peopleList …

JVM命令行监控工具之jmap(JVM Memory Map)

jmap简介 jmap(JVM Memory Map)一方面可以获取dump文件&#xff08;堆转储快照文件&#xff0c;二进制文件&#xff09;&#xff0c;它还可以获取目标Java进程的内存相关信息&#xff0c;包括Java堆各区域的使用情况、堆中对象的统计信息、类加载信息等。 选项作用-dump生成…

jmap详解

这里写自定义目录标题 简介理论知识实践部分1. 找到进程id2. 生成内存快照3. Java堆和方法区的详细信息、内存空间使用率、当前用的是哪种收集器 简介 这个命令非常重要&#xff0c;主要是生成java进程当前&#xff08;当前指的是执行命令的时刻&#xff09;内存堆转储快照&am…

jmap的使用以及内存溢出分析

jmap的使用以及内存溢出分析 jmap(java内存映像工具) jmap(Memory Map for Java&#xff09;命令用于生成堆转储快照&#xff08;一般称为heapdump或dump文件&#xff09;。还有几种方式获取dump文件&#xff1a;使用JVM参数选项-XX:HeapDumpOnOutOfMemoryError参数&#xff…

Java的jmap命令使用详解

jmap命令简介 jmap&#xff08;Java Virtual Machine Memory Map&#xff09;是JDK提供的一个可以生成Java虚拟机的堆转储快照dump文件的命令行工具。除此以外&#xff0c;jmap命令还可以查看finalize执行队列、Java堆和方法区的详细信息&#xff0c;比如空间使用率、当前使用…

Python Numpy .npy文件打开

首先找到你的npy文件的路径&#xff08;我的npy文件在D盘下&#xff0c;名字叫test.npy&#xff09; 2 打开编写python的软件&#xff08;我的软件是pycharm&#xff09; 3 新建一个python文件&#xff0c;用于后面的编程使用。&#xff08;我先建的python文件名叫test&#xf…

Numpy文件交互:.npy和.npz有什么区别?

文章目录 saveloadsavezsavez_compressed Numpy提供了以.npy为后缀的文件存储方案&#xff0c;与这种文件格式密切相关的读、写函数分别是np.load和np.save。通过savez可以一次性存储多个数组&#xff0c;并可通过load以键值对的形式读取出来&#xff1b;如果觉得文件太大&…

什么是npy文件,为什么要用npy格式保存文件?

文章目录 一、官方文档&#xff08;中文&#xff09;二、官方文档&#xff08;英文&#xff09;三、为什么要用npy文件保存文件四、读取和保存&#xff08;1&#xff09;加载npy文件&#xff0c;并将npy文件写入一个txt文件&#xff08;2&#xff09;保存npy文件&#xff08;3&…