vue + echarts 省份地图 以及打包后地图加载不出来(比较详细)「建议收藏」

vue + echarts 省份地图 以及打包后地图加载不出来(比较详细)「建议收藏」刚开始地图怎么也出不来,经过解决,是因为echarts.min.js引入位置在index.html中引入需要的js版本按照自己需要的来<scriptsrc=”./static/plugins/echarts-5.1.2/echarts.common.min.js”></script><scriptsrc=”./static/plugins/echarts.min.js”></script>(必须引入,地图才能加载)全局引入im

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

刚开始地图怎么也出不来,经过解决,是因为echarts.min.js 引入位置

在index.html 中引入需要的js
版本按照自己需要的来
<script src="./static/plugins/echarts-5.1.2/echarts.common.min.js"></script>
<script src="./static/plugins/echarts.min.js"></script>    (必须引入,地图才能加载)
  • 全局引入
import * as echarts from "echarts";
Vue.prototype.$echarts = echarts
  • 局部引入
    我写的时候全局引入没有效果,在页面还是得引入,必须是 * 这样的
import * as vueEcharts from "echarts";
  • 在自己的页面引入需要的省份js
const guangxiJson = require("@/utils/js/guangxi.json");
  • 在该网站上下载需要的地图json(也可以百度搜 都有的)
    http://datav.aliyun.com/tools/atlas/#&lat=30.37018632615852&lng=106.68898666525287&zoom=3.5

1.给一个盒子 宽高必须给

<div class="map" id="mapBox" style="width:100%;height:100%;"></div>

2.在这里调用

mounted() {
    this.$nextTick(() => {
      vueEcharts.registerMap("guangxi", guangxiJson);
        this.guangxiMap();
    });
  },

3.methods (直接复制就好了,里面的标注位置可以自己修改,或者增加)
上面的标注我是根据这个改的
这是标注参照

guangxiMap() {
// 获取经纬度数据
const seriesList = [
{
// image: zaixian,
data: [
{
value: [106.9, 27.7],
},
{
value: [105.29, 27.32],
},
{
value: [106.04, 27.03],
},
{
value: [104.82, 26.58],
},
],
},
{
// image: shangxian,
data: [
{
value: [107.43, 28.56],
},
],
},
{
// image: lixian,
data: [
{
value: [107.5, 27.76],
},
],
},
];
// 自定义图标
const series = seriesList.map((v) => {
return {
type: "custom", //配置显示方式为用户自定义
coordinateSystem: "geo",
renderItem(params, api) {
//具体实现自定义图标的方法
return {
type: "image",
style: {
image: v.image,
x: api.coord([
v.data[params.dataIndex].value[0],
v.data[params.dataIndex].value[1],
])[0],
y: api.coord([
v.data[params.dataIndex].value[0],
v.data[params.dataIndex].value[1],
])[1],
width: "29",
height: "35",
},
};
},
data: v.data,
};
});
// 上面的标注坐标
var gdGeoCoordMap = {
"南宁烟厂": [108.320004, 22.82402],
"柳州烟厂": [109.411703, 24.314617],
"桂林市": [110.299121, 25.274215],
"梧州市": [111.297604, 23.474803],
"北海市": [109.119254, 21.473343],
"防城港市": [108.345478, 21.614631],
"钦州市": [108.624175, 21.967127],
"贵港市": [109.602146, 23.0936],
"玉林市": [110.154393, 22.63136],
"百色市": [106.616285, 23.897742],
"贺州市": [111.552056, 24.414141],
"静兰烟厂": [109.455500, 25],
"来宾市": [109.229772, 23.733766],
"崇左市": [107.353926, 22.404108]
};
//**我上面只写了三个标注,如果需要其他的,在这里继续添加就好了,name必须和上面的一样**
var data = [{
name: "南宁烟厂",
// value: 4,
},
{
name: "柳州烟厂",
value: 4617,
},
{
name: "静兰烟厂",
value: 5899,
},
];
var img = 'image://'
var img2 = 'image://'
var convertData = function(data) {
var res = [];
for (var i = 0; i < data.length; i++) {
var geoCoord = gdGeoCoordMap[data[i].name];
if (geoCoord) {
res.push({
name: data[i].name,
value: geoCoord.concat(data[i].value)
});
}
}
return res;
};
// options
const distributionOptions = {
tooltip: {
show: true, // 鼠标移入是否触发数据
trigger: "item", // 触发方式
triggerOn: "click",
formatter: "名称:{b}<br />坐标:{c}",
},
series:[
{
tooltip: {
show: false,
},
type: 'effectScatter',
coordinateSystem: 'geo',
rippleEffect: {
scale: 10,
brushType: 'stroke',
},
showEffectOn: 'render',
itemStyle: {
normal: {
color: '#00FFFF',
}
},
label: {
normal: {
color: '#fff',
},
},
symbol: 'circle',
symbolSize: [10, 5],
data: convertData(data),
zlevel: 1,
},
{
type: 'scatter',
coordinateSystem: 'geo',
itemStyle: {
color: '#00FFF6',
},
symbol: img,
symbolSize: [32, 41],
symbolOffset: [0, -20],
z: 999,
data: convertData(data),
},
{
type: 'scatter',
coordinateSystem: 'geo',
label: {
normal: {
show: true,
formatter: function(params) { 
var name = params.name
var value = params.value[2]
var text = `{
{tline|${name}}`
return text;
},   
color:'#fff',
rich: {
fline: {
padding: [0, 25],
color: '#fff',
fontSize: 14,
fontWeight:400
},
tline: {
padding: [0, 27],
color: '#ABF8FF',
fontSize: 12,
},
}
},
emphasis: {
show: true
}
},
itemStyle: {
color: '#00FFF6',
},
symbol: img2,
symbolSize: [100, 50],
symbolOffset: [0, -60],
z: 999,
data: convertData(data),
}
],
geo: {
//引入广西省的地图
map: "guangxi",
layoutCenter: ["50%", "50%"], //设置后left/right/top/bottom等属性无效
layoutSize: "90%",
roam: false, //关闭鼠标缩放和拖动
zoom: 1,
label: {
normal: {
//静态的时候展示样式
show: true, //是否显示地图省份得名称
textStyle: {
color: "#fff",
// fontSize: 10,
fontFamily: "Arial",
},
},
emphasis: {
show: true,
//动态展示的样式
color: "#fff",
},
},
itemStyle: {
// 设置地图块的相关显示信息
normal: {
areaColor: "#1B8ADE",
borderColor: "#BA6A15",
borderWidth: 1,
textStyle: {
color: "#fff",
},
// 地图块凸起
// shadowBlur: 10,
// shadowOffsetX: 10
left: "5%",
right: "5%",
top: "5%",
bottom: "5%",
},
emphasis: {
areaColor: "#BA6A15", // hover效果
color: "#fff",
},
},
},
};
var myChart = vueEcharts.init(document.getElementById("mapBox"));
myChart.setOption(distributionOptions);
var that = this
myChart.on("click", function (params) {
//点击柳州烟厂的时候,跳转到想跳的页面
if(params.data.name == '柳州烟厂') {
that.$router.push({ path: "/faceMonitor" })
}
}); 
window.onresize = function () {
myChart.resize();
};
},

最后如果打包后的地图加载不出来:

找到自己项目里static 里面的 config 文件 (动态加载初始资源)

/**
* 动态加载初始资源
*/
;(function() {
var resList = {
icon: window.SITE_CONFIG.cdnUrl + '/static/img/favicon.ico',
css: [
window.SITE_CONFIG.cdnUrl + '/static/css/app.css',
],
js: [
// 插件, 放置业务之前加载, 以免业务需求依赖插件时, 还未加载出错
// 插件 - echarts
window.SITE_CONFIG.cdnUrl + '/static/plugins/echarts-3.8.5/echarts.common.min.js',
//***在这里引入需要的 js 文件  就可以了!!!!!!!!!!!!!!!!!!很重要***
window.SITE_CONFIG.cdnUrl + '/static/plugins/echarts.min.js',
]
};
// 图标
// 样式
})();

希望可以帮助到大家!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/182653.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 【示例教程】使用Leadtools对身份证进行识别和表单模板创建

    【示例教程】使用Leadtools对身份证进行识别和表单模板创建

  • plot颜色设置_matlab plot颜色

    plot颜色设置_matlab plot颜色怎么分别设置点和线条的颜色?p.plot(color=”r,secondary_y=True,style=’-*’,linewidth=2)怎么把点和线设置为两种不同的颜色?

    2022年10月16日
  • String头文件_string头文件的作用

    String头文件_string头文件的作用首先说string的头文件1、<string>包装了std的C++头文件2、<string.h>旧的C头文件3、<cstring.h>旧C头文件的std版本,切记,这不是cstring的头文件详见effectivec++的第49条再说cstring的头文件注:VC9编译环境下1、<atlstr.h&g…

  • 关于服务器安装docker后无法ping通内网

    关于服务器安装docker后无法ping通内网

  • 机器学习——决策树模型:Python实现

    机器学习——决策树模型:Python实现机器学习——决策树模型:Python实现欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML图表FLowchart流程图导出与导入导出导入欢迎使用Markdown编辑器你好!这是你第一次使用Markdown编辑器所展示的欢迎页。如果你

    2022年10月19日
  • 《提问的艺术》读后感「建议收藏」

    《提问的艺术》读后感「建议收藏」前言提问前他明明能帮到我却不帮我提问前必知必会的一些事关于搜索引擎提问时找准对象学会停顿组织你的问题清晰的发问低声下气代替不了做自己的家庭作业删除无意义的要求不要把问题标记为紧急即使对你而言的确如此礼貌总是有益的对待无礼提问禁区总结前言众所周知,你所提技术问题的解答很大程度上取决于你提问的方式与解决此问题的难度,但是怎么清楚的让有经验的人明白你表述的问题,让你获得最

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号