vue3echarts展示

<div id="user_region" style="height: 600px; width: 100%"></div>

import {

defineComponent,

toRefs,

reactive,

getCurrentInstance,

ref,

onMounted,

markRaw,

} from "vue";

import * as echarts from "echarts";

onMounted(() => {

getMap();

createRegion();

});

const createRegion = () => {

let mapChartInstance = null;

// 获取地图容器

let mapChart = document.getElementById("user_region");

mapChartInstance = markRaw(

echarts.init(mapChart, undefined, { devicePixelRatio: 2, renderer: "svg" })

);

// 注册地图

echarts.registerMap("China", China);

setTimeout(() => {

mapChartInstance.setOption(options.value);

}, 800);

};

const options = ref({

title: {

left: 10,

top: 10,

textStyle: {

color: "#000",

fontSize: 16,

},

},

visualMap: {

show: false,

min: 0,

max: 10000,

type: "piecewise",

right: 50,

bottom: 20,

inRange: {

//控制颜色深浅

opacity: 0.35,

},

pieces: [

// 自定义每一段的范围,以及每一段的文字

// { gte: 50, color: "#17459e" },

// { gte: 20, lte: 50, color: "#3886e1" },

// { gte: 10, lte: 20, color: "#73b3f3" },

// { gte: 1, lte: 10, color: "#c0ddf9" },

// { lte: 1, color: "#ebedf0" },

],

},

series: [

{

name: "景区",

type: "map",

map: "China",

geoIndex: 0,

//假数据

// data: [

// {

// name: "那曲市",

// value: 1,

// type: { name: "2222", value: 1111 },

// },

// { name: "阿里地区", value: 2, type: { name: "42", value: 1231 } },

// { name: "日喀则市", value: 3, type: { name: "5124", value: 333 } },

// { name: "拉萨市", value: 4, type: { name: "345345", value: 3 } },

// { name: "昌都市", value: 5, type: { name: "25435", value: 4 } },

// { name: "山南市", value: 5, type: \[\] },

// ],

data: \[\],

label: {

show: true,

},

},

],

tooltip: {

// 自定义弹窗

// 鼠标引入省份,不断触发.params 对象.当前省份的信息.

formatter: function (params) {

console.log(params, "9999999999999");

let ZRtitle = ``;

let ZRtitletwo = ``;

if (params && params.data) {

if (params.data.type && params.data.type.length > 0) {

params.data.type.forEach((item) => {

console.log(item, "8888");

ZRtitle += `{item.name}:{item.value}件<br/>`;

});

}

if (params.data.level && params.data.level.length > 0) {

params.data.level.forEach((item) => {

console.log(item, "8888");

ZRtitletwo += `{item.name}:{item.value}件<br/>`;

});

}

}

return (

params.name +

"<br>" +

"事件类型" +

"<br>" +

ZRtitle +

"事件级别" +

"<br>" +

ZRtitletwo

);

},

},

geo: {

// 使用地图

map: "China",

label: {

//显示地域标签

show: true,

//标签字体颜色

color: "#ffffff",

},

roam: true,

zoom: 1,

layoutCenter: "50%", "50%",

//地图尺寸

layoutSize: "90%",

// 缩放

aspectScale: 1,

itemStyle: {

//区域边框宽度

borderWidth: 0.5,

//区域边框颜色

borderColor: "#d1d1d1",

//区域颜色

areaColor: "#eeeeee",

},

emphasis: {

//高亮状态下的多边形和标签样式

// 控制地图滑过后的颜色

label: {

color: "#fff",

fontSize: 12,

},

itemStyle: {

areaColor: "#1bc1ad",

borderColor: "blue",

},

},

},

});

数据:

const getMap = async () => {

let res = await getCityCount({});

if (res.code == 200) {

options.value.series0.data = res.data;

}

};

相关推荐
张龙68710 分钟前
构建生产级 AI Agent:工具调用与记忆架构实战指南
前端
kyriewen1 小时前
2026 年了,还在用 Node.js?Bun 迁移实战:20 分钟搞定,附踩坑记录
前端·javascript·node.js
青山Coding3 小时前
Cesium应用(八):物体运动的实现思路
前端·cesium
用户41659673693553 小时前
Android WebView 加载 file:// 离线页面调试教程
android·前端
Asmewill3 小时前
curl命令学习笔记一
前端
我是一只快乐的小螃蟹3 小时前
1.2 ArrayList 源码解析
前端
星栈3 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:再把新建、编辑和交付补上
前端·rust·前端框架
我是一只快乐的小螃蟹3 小时前
1.1 HashMap (JDK1.8) 源码解析
前端
爱勇宝6 小时前
小红花成长新版:模板来了,鼓励也更容易开始
前端·后端·程序员
竹林8186 小时前
Solana前端开发:我在一个NFT铸造页面上被@solana/web3.js的Connection和Transaction签名坑了两天
前端