前端大屏展示可视化——地图的绘制(持续更新)

一、ECharts

1、安装

javascript 复制代码
npm install echarts

2、引入

javascript 复制代码
import * as echarts from 'echarts';

3、渲染

3.1、前期准备,基础配置
javascript 复制代码
// 地图实例
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中定义一个有宽高的容器

html 复制代码
<div id="mainMap" style="width: 100%;height: 100%;"></div>

获取节点,初始化实例

javascript 复制代码
myChart.value = echarts.init(document.getElementById('mainMap'));
3.3、监听

监听窗口大小的变化

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

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

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

4、其他

4.1、加入事件

要在实例渲染之前执行

javascript 复制代码
  // 点击事件
  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、完整代码

javascript 复制代码
<script setup>
import * as echarts from 'echarts';
import { onMounted, reactive, ref, onBeforeUnmount } from 'vue';
import geoJSON from './geo.json';

defineOptions({name: 'echarts'});
onMounted(() => {
  loadEchartsMap();
});

// 地图实例
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',
    },
  }]
})
// 加载Echarts地图
const loadEchartsMap = () => {
  // 初始化
  myChart.value = echarts.init(document.getElementById('mainMap'));
  // 监听窗口大小变化
  window.addEventListener("resize", () => {
    if (myChart.value) myChart.value.resize();
  })
  // 点击事件
  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);
  });
  // 加载地图
  echarts.registerMap("map_area", geoJSON);
  myChart.value.setOption(option);
}

// 销毁
onBeforeUnmount(() => {
  window.removeEventListener("resize", () => {
    if (myChart.value) myChart.value.resize();
  })
  if (myChart.value) myChart.value.dispose()
})

// 子组件暴露
defineExpose({});

</script>

<template>
  <div id="mainMap" style="width: 100%;height: 100%;"></div>
</template>

<style lang="less" scoped>

</style>
相关推荐
站在风口的猪110824 分钟前
《前端面试题:CSS对浏览器兼容性》
前端·css·html·css3·html5
JohnYan1 小时前
Bun技术评估 - 04 HTTP Client
javascript·后端·bun
青莳吖2 小时前
使用 SseEmitter 实现 Spring Boot 后端的流式传输和前端的数据接收
前端·spring boot·后端
CodeCraft Studio2 小时前
PDF处理控件Aspose.PDF教程:在 C# 中更改 PDF 页面大小
前端·pdf·c#
拉不动的猪3 小时前
TS常规面试题1
前端·javascript·面试
再学一点就睡3 小时前
实用为王!前端日常工具清单(调试 / 开发 / 协作工具全梳理)
前端·资讯·如何当个好爸爸
穗余3 小时前
NodeJS全栈开发面试题讲解——P5前端能力(React/Vue + API调用)
javascript·vue.js·react.js
Jadon_z4 小时前
vue2 项目中 npm run dev 运行98% after emitting CopyPlugin 卡死
前端·npm
一心赚狗粮的宇叔4 小时前
web全栈开发学习-01html基础
前端·javascript·学习·html·web
IT瘾君4 小时前
JavaWeb:前端工程化-ElementPlus
前端·elementui·node.js·vue