前端大屏展示可视化——地图的绘制(Echarts)
创始人
2025-01-15 07:34:00
0

在这里插入图片描述

1、安装

文档

npm install echarts 

2、引入

import * as echarts from 'echarts'; 

3、渲染

3.1、前期准备,基础配置
// 地图实例 const myChart = ref(null); // 地图配置 const option = reactive({   tooltip: {     trigger: 'item',     formatter: function (params) {       return params.name + ':' + (params.value || 0);     },   },   series: [     // 地图配置     {       type: "map",       geoIndex: 0,       data: [{         name: '杭州市',         value: '333'       },{         name: '湖州市',         value: '444'       }],     },   ],   geo: [{     map: "map_area",     layoutCenter: ['50%', '50%'],     layoutSize: '92%',     z: 2,     label: {       show: true,       fontSize: 13,       color: '#1bfeff',     },   }] }) 
3.2、初始化

首先要现在HTML中定义一个有宽高的容器

获取节点,初始化实例

myChart.value = echarts.init(document.getElementById('mainMap')); 
3.3、监听

监听窗口大小的变化

  window.addEventListener("resize", () => {     if (myChart.value) myChart.value.resize();   }) 
3.4、渲染加载

geoJSON数据可通过接口获取,或自行下载保存到本地,自行引入,建议通过接口获取

   echarts.registerMap("map_area", geoJSON);   myChart.value.setOption(option); 
3.5、销毁
  window.removeEventListener("resize", () => {     if (myChart.value) myChart.value.resize();   })   if (myChart.value) myChart.value.dispose() 

4、完整代码

     

5、其他扩展

5.1、加入事件

要在实例渲染之前执行

  // 点击事件   myChart.value.on('click', (mapParams) => {     console.log('click', mapParams);   });   // 鼠标移入事件   myChart.value.on('mouseover', (mapParams) => {     console.log('mouseover', mapParams);   });   // 鼠标移出事件   myChart.value.on('mouseout', (mapParams) => {     console.log('mouseout', mapParams);   }); 
5.2、背景色/纹理填充

在这里插入图片描述

在这里插入图片描述

// 地图配置 const option = reactive({   tooltip: {     trigger: 'item',     formatter: function (params) {       return params.name + ':' + (params.value || 0);     },   },   series: [     // 地图配置     {       type: "map",       map: "map_area",       layoutCenter: ['50%', '50%'],       layoutSize: '92%',       z: 2,       label: {         show: true,         fontSize: 13,         color: '#1bfeff',       },       // itemStyle: {       //   // borderColor: '#5ec8f3', // 图形的描边颜色       //   // borderWidth: 1.8,       //   // borderType: 'dotted', // 描边类型       //   // opacity: .7,       //   areaColor: '#9967FB'       // },       itemStyle: { // 地图区域的多边形 图形样式。         borderColor: '#5ec8f3', // 图形的描边颜色         borderWidth: 1.8,         borderType: 'dotted', // 描边类型         // color: "#010e3b", // 图形颜色         opacity: .7,         areaColor: {           image: map_bg, // 支持为 HTMLImageElement, HTMLCanvasElement,不支持路径字符串           repeat: 'repeat' // 是否平铺,可以是 'repeat-x', 'repeat-y', 'no-repeat'         },       },       data: [{         name: '杭州市',         value: '333'       },{         name: '湖州市',         value: '444'       }],     },   ], }) 

相关内容

热门资讯

重大通报!三哥玩辅助器免费下载... 重大通报!三哥玩辅助器免费下载(辅助挂)起初是有挂(详细辅助德州教程)关于三哥玩辅助器免费下载机制的...
一分钟透视!哈局十三张辅助修改... 一分钟透视!哈局十三张辅助修改器(辅助挂)科技教程(起初存在有挂);致您一封信;亲爱哈局十三张辅助修...
第2分钟了解!星悦陕西老麻子辅... 第2分钟了解!星悦陕西老麻子辅助软件(辅助挂)果然有挂(详细辅助教程);致您一封信;亲爱星悦陕西老麻...
2分钟细说!海盗来了辅助器无限... 2分钟细说!海盗来了辅助器无限炮(辅助挂)本然是真的有挂(详细辅助可靠技巧)是一款可以让一直输的玩家...
第十分钟了解!凑一桌游戏辅助器... 第十分钟了解!凑一桌游戏辅助器(辅助挂)好像真的是有挂(详细辅助方法);凑一桌游戏辅助器软件透明挂更...
第六分钟插件!大当家脚本一键挂... 第六分钟插件!大当家脚本一键挂机(辅助挂)解密教程(果然存在有挂)是一款可以让一直输的玩家,快速成为...
重大通报!浙江宝宝游戏辅助(辅... 重大通报!浙江宝宝游戏辅助(辅助挂)一向是有挂(详细辅助详细教程)科技教程也叫必备教程,这是一款功能...
第七分钟辅助器!桃乐甘肃麻将下... 第七分钟辅助器!桃乐甘肃麻将下载辅助器(辅助挂)2025新版(原生有挂)1、桃乐甘肃麻将下载辅助器a...
第2分钟了解!樱花之盛挂多少钱... 第2分钟了解!樱花之盛挂多少钱(辅助挂)竟然有挂(详细辅助技巧);建议优先通过樱花之盛挂多少钱透明挂...
推荐一款!九酷互娱辅助(辅助挂... 推荐一款!九酷互娱辅助(辅助挂)往昔是有挂(详细辅助科技教程)准备好在九酷互娱辅助ia的高塔上攀登,...