js数组引用传值问题

今天下午没有任务,于是便在网站上开始练练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引用造成影响,改变数组对象可以。

知乎上有篇推荐的文章。先马了以后看。

实现JS数组的深拷贝


http://www.cnblogs.com/Loofah/archive/2012/03/23/2413665.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值