JavaScript 作用域分析

本文详细阐述了JavaScript中的作用域规则,包括块级与函数级作用域的区别、变量查找的就近原则及局部变量与参数的优先级问题,并探讨了基本类型与引用类型的传值特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

原文地址:http://www.cnblogs.com/skylar/p/3986087.html

黄金守则第一条:

    js没有块级作用域(你可以自己闭包或其他方法实现),只有函数级作用域,函数外面的变量函数里面可以找到,函数里面的变量外面找不到。

<script>

var a = 10

function aaa()

{

   alert(a)

}

function bbb()

{

   var a=20

   aaa()

}

bbb()

</script>

结果为10,在函数bbb()中定义的变量,在aaa()中无法找到,所以a的值依旧为10。


<script>

function aaa()

{

   var a=b=10

}

aaa()

alert(a)

alert(b)

结果报错a未被定义,而b正常为10。由于a前面的var,变量a仅能在函数aaa()中被找到,而b没有var声明所以被认作了全局变量。(作者所说的赋值操作自左向右个人认为是错误的)


黄金守则第二条:

   变量的查找是就近原则,去寻找var定义的变量,当就近没有找到的时候就去查找外层。

<script>

var a=10

function aaa()

{

    alert(a)

    var a=20

}

aaa()

</script>

结果a为undefined ,查找a时,就近查找在函数中的a,由于预解析的作用,a的值为undifined。(预解析之后再说)


<script>

var a=10

function aaa()

{

alert(a)

a=20

}

</script>

结果a为10,就近原则寻找的是var声明的变量,函数内没有,所以找到了全局变量a,而在输出是还没有执行修改值的语句。


黄金守则第三条:

    当参数跟局部变量重名时,优先级是等同的。

<script>

var a=10

function(a)
{
alert(a)
var a=20
}
aaa(a)
结果为10,全局变量作为参数传入,所以不需要就近查找,可以直接使用,如果alert放在“var a=20”之后,显示为20,放在函数外显示为10.


传参时,基本类型传值,引用类型传引用。(但是重新赋值之后就不是这样了喔)

var a=5
var b=a
b+=3
alert(a)
结果显示为5,值类型仅传递值,对本身没有影响。

var a=[1,2,3]
var b=a
b.pish(4)
alert(a)
结果为[1,2,3,4],b被指向了a,针对a和b的操作都是互相影响的。

var a=[1,2,3]
var b=a
b=[1,2,3,4]
alert(a)
结果为[1,2,3],b被重新定向了,不再指向a。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值