今天下午没有任务,于是便在网站上开始练练js的题。然后遇见了一道比较坑的题。
在数组 arr 末尾添加元素 item。不要直接修改数组 arr,结果返回新的数组
输入例子:
append([1, 2, 3, 4], 10)
输出例子:
[1, 2, 3, 4, 10]第一想法就是
function append(arr, item) {
var arr0=arr;
arr0.push(item);
return arr0;
}
于是,没有通过。
我又改用splice切割arr0数组。依然没有通过。
最后改用concat函数,终于通过了。
function append(arr, item) {
var arr0=[];
arr0=arr.concat(item);
return arr;
}
然后开始百度。
终于查到,数组是引用传值,而push(),pop(),splice()都是会修改调用的数组。concat()和slice()不会。
然后我又看到这样一道题。
var a = [1,2,3];
var b = a;
a = [4,5,6];
alert(b); //[1,2,3]
var a = [1,2,3];
var b = a;
a.pop();
alert(b); //[1,2]
a = [4,5,6]; //改变的是a引用本身,没有改变数组对象
a.pop(); //改变的是数组对象,a引用没有改变。
b = a; //该操作后,b直接指向数组对象,不是b指向a,a再指向数组。
//所以改变a引用并不会对b引用造成影响,改变数组对象可以。
![](https://i-blog.csdnimg.cn/blog_migrate/134ae1f4da73806584978bda9e34e65d.png)
知乎上有篇推荐的文章。先马了以后看。
实现JS数组的深拷贝
http://www.cnblogs.com/Loofah/archive/2012/03/23/2413665.html