微信小程序 setData 如何修改动态数据?

最近这段时间在写微信小程序,有一个页面需要动态修改 data 中的数据,而这里似乎是个坑。

1、正常修改

正常修改很简单,当触发 change 事件时,数据和页面都会同时发生改变。这个也不用多说,很简单的例子。

小程序 setData 中的坑,真没想到原来还可以这么玩!

2、如何修改对象中某个属性值

当你想把下面代码中 human 中的 height 的值改成 178 时,直接用 this.setData ({human.height: 178}) 会报错。

human: {  
    name: ' 张三 ',  
    height: 170  
} 

这个时候可以先用字符串拼接属性名,然后用 [] 包裹起来,这里画上,待会可能要考。

var height = 'human.height';  
this.setData({  
    [height]: 178  
})  

3、如何动态修改数组中某个值

动态修改 list [index].height 的值,和上面的例子差不多。

list: [  
    {  
        height: 170  
    },{  
        height: 175  
    },{  
        height: 178  
    }  
]  

先用字符串拼接,然后再更改,其中 index 是动态获取的数字。

var height = 'list[' + index + '].height';  
this.setData({  
    [height]: 178  
})  

4、 那个...

其实好像挺简单,果然还是我太菜,菜是原罪...

个人博客地址

首发公众号「我是玖柒后」,在路上,一起成长!

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值