zoukankan      html  css  js  c++  java
  • 小程序赋值联动的解决办法

    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);
    }
  • 相关阅读:
    RBAC概念
    Django框架的优缺点
    全文检索whoosh
    软件项目管理|期末复习(九)
    软件项目管理|期末复习(十四)
    HOJX 1003| Mixing Milk
    [转发]ACM刷题网站
    [转发]软件工具|Github上整理的一些工具
    软件项目管理|期末复习(三)
    计算机图形学|两道习题
  • 原文地址:https://www.cnblogs.com/overfly/p/10655130.html
Copyright © 2011-2022 走看看