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);
}