刚开始地图怎么也出不来,经过解决,是因为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://