高德地图为marker添加自定义属性并实时更新位置

查看官方文档,Marker类的属性,方法,事件等,官方地址:覆盖物-参考手册-地图 JS API | 高德地图API高德开放平台官网https://lbs.amap.com/api/javascript-api/reference/overlay#marker

 查看官方文档发现MarkerOptions中有extData属性,是用户自定义属性,支持JavaScript API任意数据类型,如Marker的id等。

继续往下,会发现有对应的设置与获取自定义数据的方法,

相当完美了,直接上代码:

var marker = new AMap.Marker({
    position: [Number(res.data.jingdu),Number(res.data.weidu)],
    cursor:'pointer',
    icon: carIcon,
    autoRotation: true,
    offset: new AMap.Pixel(-5, -20),
    angle:0,
    extData:ele.id   //设置自定义属性
});
methods:{
    getAllMarkers(){
        this.markers = this.mapall.getAllOverlays('marker');
        setInterval(() => {
          this.markers.forEach(ele=>{
               getDetailById(ele.getExtData()).then(res=>{ //ele.getExtData()获取id
                   ele.setPosition(
                                new AMap.LngLat(
                                    Number(res.data.jingdu),
                                    Number(res.data.weidu),false)
                   );//ele.setPosition()设置经纬度
               })
           })
                console.log("=================")
       }, 5000);
     }
},
created(){
     this.getAllMarkers();
       
    },

在页面销毁之前,记得清除定时器哦!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

甜甜凉白开

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值