Vue-baidu-map 动态刷新地图的方法
vue-baidu-map 是没有官方的刷新方法的,如果要在某个功能上实现刷新地图,我们可以使用v-if加开关思想加上侦听器,侦听这个标注数组来控制开关刷新比如我们是在地图上动态标注点位,点位是v-for,当便利的数组有数据就可以刷新地图,就可以实现标注。刚开始我是直接调用的handler ()方法,也可以实现标注,但是会因为没有实例对象报错。我的实际情况是点标注,在后续获取到故障信息的点位信息后
前言
-
vue-baidu-map 是没有官方的刷新方法的,如果要在某个功能上实现刷新地图,我们可以使用v-if加开关思想加上侦听器,侦听这个标注数组来控制开关刷新
-
比如我们是在地图上动态标注点位,点位是v-for,当便利的数组有数据就可以刷新地图,就可以实现标注。
-
刚开始我是直接调用<baidu-map>的handler ()方法,也可以实现标注,但是会因为没有实例对象报错。
-
我的实际情况是点标注,在后续获取到故障信息的点位信息后,在地图给他按钮动态标注出来。
-
在网上查找了很多办法,也没有详细的解决方案,困扰了很久,在这里总结一下
具体实现
1.地图添加一个v-if 开关控制加载 点标注是v-for points数组
<baidu-map
v-if="hackReset"
:center="center"
:zoom="zoom"
@ready="handler"
class="baidu-map"
>
<!-- 标注 -->
<div v-for="(item, k) in points" :key="k">
<bm-marker
:position="{ lng: item.lng, lat: item.lat }"
:icon="{ url: item.txt, size: { width: 28, height: 30 } }"
:title="item.title"
@mouseover="infoWindowOpen(k)"
@mouseout="infoWindowClose(k)"
>
<bm-info-window
title="设备信息"
:position="{ lng: item.lng, lat: item.lat }"
:show="item.show"
>
<p v-text="item.poinser"></p>
{{ item.poinser }}
</bm-info-window>
</bm-marker>
</div>
</baidu-map>
-
data 写一个hackReset变量控制地图开关默认开
// 百度地图刷新开关
hackReset: true,
-
points数组数据格式
this.points = [
{
lng: 119.27976095105356,
lat: 26.11161188133426,
show: false,
txt: '',
title: '烟感一',
poinser: '位于2楼会议室烟感报警了'
},
{
lng: 119.2801137156272,
lat: 26.109890462480518,
show: false,
txt: '',
title: '烟感二',
poinser: '位于2楼会议室烟感报警了'
}
]
4.利用侦听器,侦听标注数组points变化,调接口有数据就是有需要标注信息,就控制地图开关刷新
watch: {
points: {
handler(newValue, oldValue) {
console.log('百度地图更新了')
this.hackReset = false
//遮罩层开关 可有可不有
this.loadinge = false
this.$nextTick(() => {
this.hackReset = true
})
}
}
},
注意:这里有一个遮罩层开关,是默认开,地图加载完毕就关掉了。因为地图加载有白屏现象,用户体验不好,所以有一个遮罩层。主页文章有。我们通过按钮点击调接口,查询标注点数组数据,利用侦听器侦听数组,有数据就是需要标注。
总结:
经过这一趟流程下来相信你也对 ue-baidu-map 动态刷新地图的方法 有了初步的深刻印象,但在实际开发中我们遇到的情况肯定是不一样的,所以我们要理解它的原理,万变不离其宗。加油,打工人!
什么不足的地方请大家指出谢谢 -- 風过无痕
更多推荐
所有评论(0)