大佬教程收集整理的这篇文章主要介绍了javascript作用域、作用域链(菜鸟必看),大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
javascript的作用域和作用域链是我学习最痛苦的一部分,因为我花了好多时间看了好多技术文档都没有理解.大体知道什么意思了,然后还说不出之所以然来.
通过我大量的测试和看技术文档总结了以下理解,虽然不是很有技术范但是确实能理解了。
1、javascript只有全局和局部之分,那些后台语言的各种修饰符都没有。在函数中不使用var则为全局。如下:
window.name="java";//全局
varlanguage=function()
alert(Name);
name="javascript";//全局
var name="JS";//局部
alert(Name);
}()
alert(Name);
上面代码中表示为全局的在都指向同一个变量,下面的定义会替换上面的。关于三个alert分别是underfind,js,javascript.这就是作用域起了作用了。
2、作用域链从0级开始依次往下排,所谓的依次往下排指的是子级的排列。在寻找变量的时候先从同级找再找父级。
在上面的例子中,
首先弹出的是language方法里的第一个alert,如果window全局是0,那么在例子中var name="js"这个就是1.第一个alert就在1中找,如果找不到在去0中找。这是它发现了同级有一个var name="js"但是它目前还没有赋值,所以弹出underfind
第二个弹出是language方法里的第二个alert,同样的他会在1里找也就是方法内部。他找到了name而且赋值了js,所以弹出的是js
第三个弹出是最下面的alert,由于在方法内部已经给全局name重新赋值了,导致弹出的是javascript。
然后增加下一个链路我们在language中顶一个方法,如下:
window.name="javascript";//全局
varlanguage=function()
alert(Name);
name="javascript";//全局
varname="JS";//局部
alert(Name);
var lovelanguage=function(){
alert(Name);
}();
}()
alert(Name);
此时lovelanguage里的alert弹出的是js因为他会找上一级也就是language里的name,所以。。。
以上就是小编为大家带来的javascript作用域、作用域链(菜鸟必看)的全部内容了,希望大家多多支持脚步之家。
以上是大佬教程为你收集整理的javascript作用域、作用域链(菜鸟必看)全部内容,希望文章能够帮你解决javascript作用域、作用域链(菜鸟必看)所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。