刚开始地图怎么也出不来,经过解决,是因为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;};// optionsconst 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.namevar 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: 10left: "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 = thismyChart.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: [// 插件, 放置业务之前加载, 以免业务需求依赖插件时, 还未加载出错// 插件 - echartswindow.SITE_CONFIG.cdnUrl + '/static/plugins/echarts-3.8.5/echarts.common.min.js',//***在这里引入需要的 js 文件  就可以了!!!!!!!!!!!!!!!!!!很重要***window.SITE_CONFIG.cdnUrl + '/static/plugins/echarts.min.js',]};// 图标// 样式
})();

希望可以帮助到大家!

vue + echarts 省份地图 以及打包后地图加载不出来(比较详细)相关推荐

  1. vue+echarts中国地图+省市级地图(全程教学,你也可以)

    echarts+vue中国地图,点击进入省级地图 VUE+Echarts+省市地图钻取(简洁版,超详细) 以上两篇来自站内,是本文的主要参考来源. 首先上才艺 首先需要引入 echarts 包 npm ...

  2. Vue Echarts 显示地图且根据坐标设置标注点

    Vue Echarts 显示地图且根据坐标设置标注点 哎哟我去 我就想用Echarts在页面上画一张地图,这张地图显示全国,然后我有几个坐标点的经纬度信息,需要在这个地图上根据经纬度标注在Echart ...

  3. Vue+Echarts+百度地图 小例子

    刚学完Echarts后,看到一些官方例子,粘贴代码下来却实现不了相应的效果,经过一番了解,发现还要引入百度地图,记录详细过程如下. 1.安装echarts(使用3.x,4.x) npm install ...

  4. vue+ echarts实现地图(中国地图)

    ** vue+ echarts实现地图(中国地图) ** <div class="myChartMap" id="myChartMap" >< ...

  5. vue+echarts 区域地图绘制(街道)

    vue+echarts 区域地图绘制(街道) 1.以下是本人参考别的博主的链接 2.需要用到的资源 3.获取地图JSON (1)[阿里云](http://datav.aliyun.com/portal ...

  6. eCharts省份地图配置及方法

    eCharts省份地图配置及方法 文章目录: 广东地图使用方法 广东地图使用方法 var geoCoordMap = { "广州":[113.30,23.20] }; var co ...

  7. Vue+Echarts+百度地图API

    Vue+Echarts+百度地图API 不容易啊,又注册了一个地图账户 使用npm安装方式 去百度地图官网申请key,也就是地图API密钥AK 在vue项目的public文件夹中的index.html ...

  8. maven强制刷新本地包:(用于打包后重新加载)

    强制刷新本地包:(用于打包后重新加载) mvn clean install -Dmaven.test.skip=true -e -U

  9. vue echarts 中国地图省级联动+散点图(各省json文件及china.js)

    最近用echarts 做个散点图,且省级联动,效果图如下: 1.安装echarts cnpm install echarts --save 2.引入echarts.中国地图及省份地图json impo ...

  10. 前端(以Vue为例)webpack打包后dist文件包如何部署到django后台中

    由于现在前端使用的三大框架配合webpack可以实现快速打包,为部署到服务端提供了非常大的便利,那么在前端打包后,应该做些什么可以部署到django的后台中呢? 1.打包后文件包dist 进入到 di ...

最新文章

  1. 22 款神经网络的设计和可视化工具
  2. Abbreviation
  3. compilation error错误是什么原因_了解如何使用Try,Throw,Catch和Last处理JavaScript错误...
  4. Python Tkinter之variable用法
  5. php把buffer转化为图片_干货:如何提升转化率?5个优化转化率的tips
  6. 新版FMEA软件参数图(P图)免费申请试用(FMEAHunter)
  7. 钣金行业精益化生产和管理的必要性
  8. 科大讯飞语音合成使用小记
  9. Unity3D 物体移动到指定点
  10. 《Metasploit魔鬼训练营》 第二、三章
  11. canvas-vue彩色丝带展示
  12. 利用Python对Excel按列值筛选并拆分表格到多个文件
  13. 天池精准医疗大赛——人工智能辅助糖尿病遗传风险预测
  14. 论文查重格式有什么影响?
  15. 推荐WebSocket、Https移动端(iOS)抓包工具mitmproxy
  16. 基于vue和ElementUI时间选择控件的封装
  17. 可以办理软件著作权的部门有哪些
  18. u盘里的文件删除了怎么恢复
  19. 走向大佬第一步,构造函数真武术
  20. fiddler的下载安装和初步操作

热门文章

  1. Thoughtworks QA测试一面凉经
  2. 如何快速构建社交APP中的语音房
  3. 56: Recv failure: Connection was reset和55错误解决办法
  4. Ego的JavaWeb笔记
  5. python编程100例海绵宝宝-Python_Turtle库画一只派大星
  6. 世界顶级音响品牌排名
  7. 设计模式之装饰器模式
  8. 北京地区2009年春运火车票购买指南(V2.5)
  9. 使用快捷指令和carplay发送停车位置(高德地图)
  10. 计算机科学与技术双一流排名,计算机科学与技术学科排行榜(大学名单大全2020版)...