美文网首页
js数组复制(不改变原数组)

js数组复制(不改变原数组)

作者: yancolin | 来源:发表于2017-08-17 14:05 被阅读1205次

需要从后台取出数据,在前台接收并要保存在一个全局变量,因为之后还要对此使用此全局变量。

全局变量 var globalarr = [];

后台取出的数组变量 var arr = [{ 'id' : 1, 'price' : '5.0' },{ 'id' : 2, 'price' : '10.00' },{ 'id' : 3, 'price' : ' 20.00 ' }];

一般情况下如果使用等号赋值,会连同原数级的地址复制,如果在此后操作原数组,会影响原数组的元素。

例 1:(赋值且复制数组地址)

var globalarr = arr;     // 此处globalarr 和 arr 一样拥有三个对象数组元素,且globalarr和arr 同享内存地址。

console.log( globalarr );  

console.log( arr );

// 上面的打印结果如下:

// 新建一个对象数组ms,并push进globalarr,打印出,看到globalarr和arr都改变。

var ms = {};

ms.id="10";

ms.price='1000.00';

globalarr.push(ms);

console.log(globalarr);

console.log(arr);

// 再打印的结果如下:

这时,发现只单独push元素到gloalarr中,原数组arr 也发生了改变。


例 2:(只赋值不复制数组地址方法一)

var globalarr = [];

var arr =  [{'id':1,'price':'5.0'},{'id':2,'price':'10.00'},{'id':3,'price':' 20.00 '}];

globalarr = arr.slice();    // 我们用slice函数来赋值数组

var ms = {};

ms.id="10";

ms.price='1000.00';

globalarr.push(ms);

console.log('ms-globalarr=>',globalarr);

console.log('ms-arr=>',arr);

我们发现slice函数赋值是不会影响原数组的。

例 3:(只赋值不复制数组地址方法二)

var globalarr = [];

var arr =  [{'id':1,'price':'5.0'},{'id':2,'price':'10.00'},{'id':3,'price':' 20.00 '}];

for(vari in arr )

{

var v = arr[i];

var obj = {};

obj.id= v.id;

obj.price= v.price;

globalarr.push(obj);

}

var ms = {};

ms.id="10";

ms.price='1000.00';

globalarr.push(ms);

console.log('ms-globalarr=>',globalarr);

console.log('ms-arr=>',arr);

例4:(只赋值不复制数组地址方法三)

var globalarr = [];

var arr =  [{'id':1,'price':'5.0'},{'id':2,'price':'10.00'},{'id':3,'price':' 20.00 '}];

var x = globalarr.concat(arr);

var ms = {};

ms.id="10";

ms.price='1000.00';

x.push(ms);

console.log('after=>x',x);

console.log('after=>arr',arr);

相关文章

  • js数组复制(不改变原数组)

    需要从后台取出数据,在前台接收并要保存在一个全局变量,因为之后还要对此使用此全局变量。 全局变量 var glob...

  • 前端学习大纲-基础篇

    js基础 数组操作哪些会改变原数组(pop、splice、reverse等等)哪些不会改变原数组(map、redu...

  • js 数组反转, 不改变原来的数组

    array.reverse(), 会改变原来的数组, 并返回该数组 如果要不改变原数组, 需要完全复制一份新的数组

  • 浅析iOS的浅复制与深复制

    原文:浅析iOS的浅复制与深复制 最近同事问我一个问题:原数组A,进行复制得到数组B,改变数组B的Person元素...

  • js-数组克隆

    数组克隆不考虑原数组是否发生改变 数组克隆原数组不发生改变

  • 数组Array里面改变数组的和不改变数组的分类。

    改变原数组的: 不改变原数组的:

  • JavaScript数组常用方法整理

    js数组常用方法整理 Array.push()  向数组的末尾添加一个或多个元素,并返回新的数组长度。原数组改变。...

  • JS数组

    JS数组 一、语法 二、伪数组 概念:没有数组共有属性的数组 三、转化 四、合并两个数组或字符串 注:不会改变原数...

  • js06 随堂笔记 2/13

    颠倒 数组中的元素顺序 改变原数组的值 forEach() 方法 迭代器函数 二维数组 栈和队列 JS 开头入...

  • js 数组

    js 中数组的长度发生改变,数组就真的发生改变,快速清空数组就让数组长度为0js 数组的方法

网友评论

      本文标题:js数组复制(不改变原数组)

      本文链接:https://www.haomeiwen.com/subject/tcvgrxtx.html