解决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

 

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值