vue3+ECharts实现可视化中国地图

news2024/11/14 14:00:40

目录

版本问题解决

中国地图实现


版本问题解决

目前echarts的最新版本为5.5.1

echarts在4.9.0版本以后移除了中国地图,所以如果的你的版本高于4.9.0就需要手动导入中国地图。版本低于或者等于4.9.0则不需要导入。

这里我分享一种导入方法:

1.将项目的echarts版本切换为4.9.0

 

npm install echarts@4.9.0

2.切换成功后我们打开node_modules目录并找到echarts的依赖包

3.展开echarts目录会发现有个map目录,我们把map目录复制一份可以先保存到桌面 。

需要注意的是不要直接在vscode里面复制,可能会失败建议直接在windows文件系统打开项目复制如下图:

4.复制好先找个目录保存

5.接着就可以把项目中的echarts版本切换回原先版本了。

这里我切换回最新版本。

npm install echarts@latest

切换回最新版echarts依赖包下是没有map目录的

 

 6.现在就可以导入了

复制map文件夹到echarts依赖包下如图:

中国地图实现

1.在vue的main.js/ts入口文件导入echarts和导入中国地图

 

// 导入echarts图表库及其中国地图JSON数据
import * as echarts from 'echarts'
import china from 'echarts/map/json/china.json' // 导入china包
echarts.registerMap('china', china)

2. 现在就可以编写中国地图组件了代码如下

<template>
    <!-- 地图容器 -->
    <div class="map" ref="chartContainer"></div>
</template>

<script setup>
import { onMounted, ref } from 'vue';
import * as echarts from 'echarts';
import 'echarts/map/js/china'; // 导入中国地图数据

// 定义地图容器的引用
const chartContainer = ref(null);

// 初始化地图的配置项
const option = ref({
    tooltip: {
        trigger: 'item' // 鼠标悬浮时显示提示信息
    },
    visualMap: {
        min: 0, // 最小值
        max: 1000, // 最大值
        left: 'left', // 位置
        top: 'bottom', // 位置
        text: ['高', '低'], // 文本
        calculable: true // 是否显示拖拽用的手柄
    },
    series: [
        {
            name: '数据', // 系列名称
            type: 'map', // 类型为地图
            map: 'china', // 使用的地图类型,这里是中国地图
            label: {
                show: true // 显示地图区域名称
            },
            data: [
                { name: '北京', value: 10 },
                { name: '天津', value: 200 },
                { name: '上海', value: 300 },
                { name: '山东', value: 90 },
                { name: '河北', value: 500 },
                { name: '河南', value: 800 },
                { name: '江苏', value: 700 },
                { name: '浙江', value: 600 },
                // 继续添加更多省份数据项
            ]
        }
    ]
});

// 清理省份名称的函数,去掉省份名称的常见后缀
function cleanProvinceName(provinceName) {
    const suffixes = ["市", "省", "自治区", "特别行政区"];
    for (let suffix of suffixes) {
        provinceName = provinceName.replace(new RegExp(suffix + "$"), "");
    }
    return provinceName;
}

// 初始化地图函数,创建echarts实例并设置选项
const init = () => {
    const chart = echarts.init(chartContainer.value);
    chart.setOption(option.value);
}

onMounted(() => {
    init();
});

</script>

<style scoped>
.map {
    width: 800px;
    height: 650px;
}
</style>

效果展示

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1925736.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端JS特效第34波:jQuery支持拖拽图片上传的图片批量上传插件

jQuery支持拖拽图片上传的图片批量上传插件&#xff0c;先来看看效果&#xff1a; 部分核心的代码如下&#xff1a; <!DOCTYPE html> <html lang"en"> <head> <meta charset"UTF-8"> <title>jQuery支持拖拽图片上传的图片批…

J027_递归算法

一、求n的阶乘 n的阶乘&#xff1a;1*2*3*4*...*n package com.itheima.d01_file;public class DiguiTest1 {public static void main(String[] args) {//求n的阶乘System.out.println(f(3));System.out.println(f(4));System.out.println(f(5));}private static int f(int n…

[激光原理与应用-111]:南京科耐激光-激光焊接-焊中检测-智能制程监测系统IPM介绍 - 15 - 常见缺陷与波形特征

目录 前言&#xff1a;激光焊接时的光谱特征 可见光 反射光 红外热辐射光 总结 一、动力电池 - 模组 - BusBar焊接 1.1 概述 1.2 没有缺陷波形&#xff1a;一条焊缝 1.3 保护气缺失 1. 可见光 2. 反射光 3. 红外光 综合分析 1.4 功率衰减 1. 可见光 2. 反射光 …

捷配生产总结-PCB上器件布局不好对SMTDIP的影响

在电子制造领域&#xff0c;PCB&#xff08;印刷电路板&#xff09;的设计至关重要&#xff0c;其中器件的布局更是影响着整个生产流程的效率和质量。特别是对于 SMT&#xff08;表面贴装技术&#xff09;和 DIP&#xff08;双列直插式封装&#xff09;这两种常见的组装工艺&am…

STM32之七:SPI通信

目录 1.SPI通信简介 1.1 主从模式 1.2 4根通信线 1.3 数据传输 2. SPI总线时序及其4种工作模式 2.1 SPI数据移位示意 2.2 SPI四种工作模式 2.2.1 mode 0 &#xff1a;CPOL 0,CPHA0 2.2.2 mode 1&#xff1a; CPOL 0&#xff0c;CPHA 1 2.2.3 mode 2&#xff1a; C…

2024-07-14 Unity插件 Odin Inspector1 —— 插件介绍

文章目录 1 介绍2 模块3 学习目的 1 介绍 ​ Odin Inspector 是 Unity 的一个插件&#xff0c;拥有强大、自定义和用户友好的编辑器&#xff0c;而无需编写任何自定义编辑器代码&#xff0c;使得编程过程中的数据可视化更容易实现。 ​ 具体功能包括&#xff1a; 更舒适美观…

新一代大语言模型 GPT-5 对工作与生活的影响及应对策略

文章目录 &#x1f4d2;一、引言 &#x1f4d2;二、GPT-5 的发展背景 &#x1f680;&#xff08;一&#xff09;GPT-4 的表现与特点 &#x1f680;&#xff08;二&#xff09;GPT-5 的预期进步 &#x1f4d2;三、GPT-5 对工作的影响 &#x1f680;&#xff08;一&#xf…

FreeRTOS学习(1)STM32单片机移植FreeRTOS

一、FreeRTOS源码的下载 1、官网下载 FreeRTOS官方链接 官方下载速度慢&#xff0c;需要翻墙&#xff0c;一般选择第一个 2、直接通过仓库下载 仓库地址链接 同样很慢&#xff0c;甚至打不开网页&#xff0c;也不建议使用这种方法。 3、百度网盘 链接&#xff1a;https:…

ArrayList模拟实现

ArrayList模拟实现 ArrayList 的初步介绍常见操作 ArrayList 的简单模拟实现 ArrayList 的初步介绍 ArrayList也叫做顺序表&#xff0c;底层是一个数组。 在创建顺序表 时就应该规定 里面元素的数据类型&#xff0c;其中不能直接传基本数据类型&#xff0c;例如int、char。需要…

超简易高效的 AI绘图工具—与sd-webui一致界面,6G显存最高提升75%出图速率!(附安装包)

大家好&#xff0c;我是灵魂画师向阳 今天给大家分享一个基于Stable Diffusion WebUI 构建的AI绘图工具—sd-webui-forge&#xff0c;该工具的目标在于简化插件开发&#xff0c;优化资源管理&#xff0c;加速推理。 Forge承诺永远不会对Stable Diffusion WebUI用户界面添加不…

链接追踪系列-09.spring cloud项目整合elk显示业务日志

准备工作&#xff1a; 参看本系列之前篇&#xff1a;服务器安装elastic search 本机docker启动的kibana-tencent 使用本机安装的logstash。。。 本微服务实现的logstash配置如下&#xff1a; 使用腾讯云redis 启动本机mysql 启动本机docker 启动nacos,微服务依赖它作为…

rollup打包工具

rollup打包工具 在学习vite和vue3源码的时候&#xff0c;接触到了rollup&#xff0c;所以过来学习一下 什么是rollup rollup是一个模块化的打包工具&#xff0c;会将javascript文件进行合并。比起webpack&#xff0c;webpack在打包的时候会进行代码注入(保障兼容性)&#xf…

fortran简单排序算法,对一维、二维矩阵进行正序或倒序排序

fortran简单排序算法&#xff0c;对一维、二维矩阵进行正序或倒序排序 0. 引言1. 算法实现1.1 一维数组排序1.2 二维数组排序1.2 module文件 2. 结语 0. 引言 排序算法是计算机科学中的一项重要技术&#xff0c;它将一组数据按照特定的顺序排列起来。排序算法有很多种&#xff…

【云原生】Prometheus整合Alertmanager告警规则使用详解

目录 一、前言 二、Altermanager概述 2.1 什么是Altermanager 2.2 Altermanager使用场景 三、Altermanager架构与原理 3.1 Altermanager使用步骤 3.2 Altermanager工作机制 3.3 Altermanager在Prometheus中的位置 四、Altermanager部署与接入Prometheus 4.1 Altermana…

Codeforces Round 797 (Div. 3) F. Shifting String

感觉这种题写多了&#xff0c;第一眼就感觉是个图论&#xff0c;很经典的排列置换问题&#xff0c;首先连边&#xff0c;然后观察样例可以知道&#xff0c;大概是多个环的大小取lcm&#xff0c;但容易发现&#xff0c;环内部的循环节也对答案有影响&#xff0c;比如一个长度为4…

threadx 线程以及优先级调整案例

以正点原子stm32 f407板子为例子&#xff0c;如何创建工程 CubeMXCubeIDE在我之前的文章里提到了&#xff0c;这里我就不多重复。 有关线程优先级的两个参数 priority和preemption&#xff0c;我们来看看在官网是如何定义的 在main.c里面添加一个printf转串口的代码&#xff0…

Binder解析精炼

Binder原理解析精炼 1 注册服务 Server进程向binder驱动向Binder驱动发起服务注册请求 向Binder驱动申请创建一个XXXService的Binder的实体&#xff0c;Binder驱动为这个XXXService创建位于内核中的Binder实体节点以及Binder的引用 Binder驱动将注册请求转发给ServiceManager进…

Manim学习笔记05:实现向量的加法动画

以同一点 O&#x1d442; 为起点的两个已知向量 →a&#x1d44e;→&#xff0c; →b&#x1d44f;→&#xff0c;以 OA&#x1d442;&#x1d434;&#xff0c;OB&#x1d442;&#x1d435; 为邻边作 □OACB◻&#x1d442;&#x1d434;&#x1d436;&#x1d435;&#xff…

Yolov8 姿态估计

原文:Yolov8 姿态估计 - 知乎 (zhihu.com) YOLOv8论文还没有,官方默默又加了新模型:姿态估计。 现在你可以用YOLOv8做目标检测、实例分割、图像分类、目标跟踪、姿态估计,未完待续。。。。。。 一、Yolov8姿态估计 Yolov8的姿态估计模型是在COCO数据集训练的,目前支持…

python+Selenium自动化之免登录(cookie及token)

目录 cookie免登录 通过接口获取cookie 启用浏览器绕过登录 添加token 使用登录可以减去每次登录的重复操作&#xff0c;直接操作系统登录后的菜单页面&#xff0c;也可以减少安全验证登录&#xff0c;如图像验证登录的操作。注意&#xff1a;cookie和token都有有效期。 c…