JS 的引用赋值与传值赋值

本文深入解析JavaScript中的基本类型与引用类型的存储机制及作用域特性,通过具体实例阐述了变量赋值与修改的过程,重点讲解了数字、字符串、对象和数组的数据类型区别,并分析了阿里笔试题中的变量作用域问题。
 

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


现说一下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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值