微信小程序map 动态修改markers的解决方法

微信小程序map动态markers的解决方法

先上效果图
在这里插入图片描述

这里演示点击标记点,改变他的气泡背景颜色和字体颜色

1.动态修改数据,需要用到 this.setData(),

2.markers 是一个数组,这里需要涉及setData 修改内部属性的方式:

**page.js --> onMarkerTap() **

// bindmarkertap="onMarkerTap"
onMarkerTap(res) {
    let len = this.data.markers.length
    for (let i = 0; i < len; i++) {
      if (this.data.markers[i].id == res.markerId) {
        this.setData({
          // 这里的语法是,将原本定位该属性的方式转换为字符串,再套上一个[]。
          [`markers[${i}].callout.bgColor`]: "#ffd101",
          [`markers[${i}].callout.color`]:"#1d0817"
        })
        break
      }
    }
  }

page.js --> data

data: {
  latitude: 30.66089,
  longitude: 104.08572,
  markers:[{
    id:1, 
    latitude: 30.67089,
    longitude: 104.09572,
    callout:{
      content:"小黑黑",
      borderRadius:2,
      padding:2,
      display:"ALWAYS",
      textAlign:"center",
      bgColor:"#808080",
      color:"#ffffff",
    }
  }]
}

page.html

<map 
    id="mapId"
    class="map"
    latitude="{{latitude}}" 
    longitude="{{longitude}}"
    markers="{{markers}}"
    bindmarkertap="onMarkerTap"
    bindcallouttap="onCalloutTap"
    bindlabeltap="onLabelTap"
    show-location="true"
  >
  </map>
  • 0
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值