为什么我只改了JS数组中的一个对象的元素的值,其他对象的元素值都跟着变了

Posted 盘思动

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么我只改了JS数组中的一个对象的元素的值,其他对象的元素值都跟着变了相关的知识,希望对你有一定的参考价值。


    var tmp_arr_1 = new Array();
    var tmp1 = {\'type\':1,\'plan_num\':200};
    tmp_arr_1.push(tmp1);
    tmp_arr_1.push(tmp1);
    
    console.log(tmp_arr_1);
    tmp_arr_1[0][\'type\'] = \'-----\';
    console.log(\'--变化一个后--\');
    console.log(tmp_arr_1);
    return;


由于数组是引用变量 ,进行引用赋值 , 其实还是原来的数组 , 也就是说 ,我赋给tmp_arr_1,其实一直都是同一个地址里存的同一个数组 , 
所以 ,最后一次修改payArr 后 ,每个引用都一起改掉了 , 那么怎么解决呢 ?

dataList[i].payArr = JSON.parse(JSON.stringify(payArr)) ; 
原理就是先把数组转换成字符串再转换成对象 ,这样会新分配一块内存新创建一个对象 ,
这是一个基础坑




    var tmp_arr_2 = new Array();
    var tmp1 = {\'type\':1,\'plan_num\':200};
    tmp_arr_2.push(JSON.parse(JSON.stringify(tmp1)));
    tmp_arr_2.push(JSON.parse(JSON.stringify(tmp1)));
    console.log(tmp_arr_2);
    tmp_arr_2[0][\'type\'] = \'-----\';
    console.log(\'--变化一个后--\');
    console.log(tmp_arr_2);
    return;




以上是关于为什么我只改了JS数组中的一个对象的元素的值,其他对象的元素值都跟着变了的主要内容,如果未能解决你的问题,请参考以下文章

List中为啥修改一个值其他值也变

js中怎么把值放入数组中

gitvue项目只改了一个页面显示修改了很多

如何用mongoose更新这个文档中的数组中的对象中的数组里的值?

JS中的常用内置对象有哪些?并列举该对象的常用方法?

js怎么取一个数组中的奇数位元素或者偶数位元素