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

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

1、正常修改

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

微信小程序 setData 如何修改动态数据?_第1张图片

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、 那个...

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

个人博客地址

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

微信小程序 setData 如何修改动态数据?_第2张图片

你可能感兴趣的:(学习摸索,Share,小程序九九八十一坑)