本文主要是介绍解决vue-baidu-map使用个性化样式mapStyle后出现白块、错误等性能问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
Vue项目中使用百度地图,用到了vue-baidu-map,但是里面用到的API是2.0,需要使用3.0的setMapStyleV2
·最近有个项目,开发2.0时发现之前使用的vue-baidu-map在使用了地图编辑器个性化样式后显示不完整,如果去掉样式原生的则没有问题。初步判定是样式的问题。
·在官方文档找到vue-baidu-map使用的是官方2.0的api,而个性编辑器的2.0版本已停止更新,打开旧版的编辑器网站也是同样显示有问题
·发现问题就是需要给2.0升级到3.0,从而可以使用3.0的setMapStyleV2这个方法
·废话不多说,进入正题,送上解决方案
解决问题
通过查阅资料,需要将源码中的API改为3.0
1、将node_modules/vue-baidu-map/components 整个文件夹复制出来
2、在src的components文件夹里新建vue-baidu-map文件夹,并把复制的文件粘贴进去
3、将如图里的2.0改成3.0
4、main.js中更改你复制之后存放的路径,如图:
然后去使用页面的组件里添加@ready="handle",方法中写入:
handle({map,BMap}){let that = this;that.map = map;map.setMapStyleV2({styleId: '在官方个性编辑器里申请的id'});},
这时候发现还是不能使用,最后步骤:
在index.html文件里引入:
<script type="text/javascript" src="https://api.map.baidu.com/api?v=3.0&ak=key"></script>
//记得ak=key那里输入你的地图key
这篇关于解决vue-baidu-map使用个性化样式mapStyle后出现白块、错误等性能问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!