js 循环如何不污染原来的对象啊! - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
coderabbit
V2EX    问与答

js 循环如何不污染原来的对象啊!

  •  
  •   coderabbit 2019-09-28 23:07:12 +08:00 2354 次点击
    这是一个创建于 2271 天前的主题,其中的信息可能已经有所发展或是发生改变。
     let data =[{},{}] console.log(data); data.forEach(function (item) { item.status = 123; }); 

    结果打印 data 的时候 里面多了个 key status 把源数据污染掉了。我不想它污染源数据,有什么办法处理呢! 还有 V2 回贴的时候 markdown 为啥没用呢!该如何回呢!

    15 条回复    2019-09-29 21:29:24 +08:00
    huihuimoe
        1
    huihuimoe  
       2019-09-28 23:10:12 +08:00 via iPhone
    lodash deep clone
    Sanko
        2
    Sanko  
       2019-09-28 23:12:22 +08:00 via Android
    序列化再反序列化
    deepdark
        3
    deepdark  
       2019-09-28 23:19:49 +08:00 via Android
    深克隆
    hackyuan
        4
    hackyuan  
       2019-09-28 23:30:22 +08:00   2
    ```js
    const newData = data.map(i => {
    return {
    ...i,
    status: 123
    }
    });
    // 仅支持浅层,多层需要 deep clone
    ```
    chuxiaonan
        5
    chuxiaonan  
       2019-09-28 23:34:05 +08:00
    data.slice().forEach/for...of
    data.map/flatMap
    很多方法感觉
    chuxiaonan
        6
    chuxiaonan  
       2019-09-28 23:35:20 +08:00
    @chuxiaonan 哎呀不对 slice()不行。。
    zhujinliang
        7
    zhujinliang  
       2019-09-29 00:11:54 +08:00 via iPhone
    用 console.log(JSON.stringify(data))
    neptuno
        8
    neptuno  
       2019-09-29 07:39:18 +08:00 via iPhone
    转成 json,再转回来,,,
    jatai
        9
    jatai  
       2019-09-29 08:33:01 +08:00 via Android
    ...展开运算符,真香
    w292614191
        10
    w292614191  
       2019-09-29 08:43:40 +08:00
    JSON.parse
    JSON.stringify
    只能用于一些简单的对象克隆。
    duzhihao
        11
    duzhihao  
       2019-09-29 11:37:35 +08:00
    只能深拷贝吧,
    rick2c
        12
    rick2c  
       2019-09-29 12:17:31 +08:00
    既然不想修改(污染),为什么要操作引用数据
    coderabbit
        13
    coderabbit  
    OP
       2019-09-29 15:09:58 +08:00
    @hackyuan 谢谢
    @rick2c 肯定要对原数据操作组装新数据。
    @chuxiaonan flatMap 我刚查了下 是 es10 的特性啊。我还停留在 es6 之前!不知道现在 bable 是否能转 es10
    chuxiaonan
        14
    chuxiaonan  
       2019-09-29 20:53:48 +08:00
    @coderabbit babel 能 transpile 的相当多 甚至很多没进入规范的都能转 比如装饰器,Observable 之类的
    SoloCompany
        15
    SoloCompany  
       2019-09-29 21:29:24 +08:00
    data.map(x -> ({...x, status: 123}))
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     1025 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 18:35 PVG 02:35 LAX 10:35 JFK 13:35
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86