JS 的引用赋值与传值赋值

 

这个问题说大不大说小不小,如果你有幸踩了这个坑,一定会找这篇文章,哈哈~


现说一下JS数字的类型:基本类型引用类型


先看下下面两个栗子:

var a = 30;
var b = a;
a = 20;
console.log( b )   // 30
 
var a = [1,2];
var b = a;
a[0] = 5;
console.log( b )  // [5,2]

简单的说:


number,string类型都是基本类型,而基本类型存放在栈区,访问时按值访问,赋值是按照普通方式赋值;


对象和数组是通过引用来赋值的,所以改变a的同时b也会跟着改变。

阿里2014年的笔试题: 

var a = 1;

var obj = {
    b: 2
};
var fn = function () {};
fn.c = 3;
 
function test(x, y, z) {
    x = 4;
    y.b = 5;
    z.c = 6;
    return z;
}
test(a, obj, fn);
alert(a + obj.b + fn.c);
 
 
 

答案:12

 首先test传递进去的实参中,a是基本类型(,复制了一份值),obj是object(指向地址,你动我也动),fn也当然不是基本类型啦。在执行test的时候,x被赋值为4(跟a没关系,各玩各的,a仍然为1),y的b被赋值为5,那obj的b也变为5,z的c变为6,那fn的c当然也会是6. 所以alert的结果应该是1+5+6 =12. (其实test不返回z也一样,z仍然改变的)。

 附上原文地址:https://www.cnblogs.com/cench/p/6019453.html
简约不简单,代码追求极致
原文地址:https://www.cnblogs.com/bitkuang/p/9814632.html