小程序赋值联动的解决办法

data: {
    flagList: [
        {"id": 1, "value": "值1"},
        {"id": 2, "value": "值2"}
    ]
}

// 将data中的flagList赋给list,并对list得value进行赋空操作,最后输出flagList。
onload: function(e) {
    let flagList = this.data.flagList;
    let list = flagList;

    for (let i = 0; i < list.length; i++) {
        list[i].value = "";
    }
    
    console.log(flagList);
}

  上述代码最后输出会发现flagList的value的值,也变为空;其中造成这种结果的原理不清楚,下面仅说下解决办法。

  将flagList转换成json字符串赋值给listTemp,listTemp再转换为json数组赋给list。

  (补充:想明白原理了,原因是数组中元素对象的赋值是引用传递。——2019.6)

data: {
    flagList: [
        {"id": 1, "value": "值1"},
        {"id": 2, "value": "值2"}
    ]
}

// 将data中的flagList赋给list,并对list得value进行赋空操作,最后输出flagList。
onload: function(e) {
    let flagList = this.data.flagList;
    let listTemp = JSON.stringify(flagList); // 1.转换为json字符串
    let list = JSON.parse(listTemp); // 2.转换为json数组

    for (let i = 0; i < list.length; i++) {
        list[i].value = "";
    }
    
    console.log(flagList);
}

转载于:https://www.cnblogs.com/overfly/p/10655130.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值