function fn(){}
fn // f fn(){} 意思是fn是个函数
var a = 1
a // 1这也是全局变量声明
这些全局作用域的变量相当于在这个页面级水平上作用,页面这里比较形象的概念,就是window。换句话说,全局变量可以看作是window的属性。
window.fn // f fn(){}
window.a // 1
题目——
每当执行一个函数,它就在一个新的作用域下了。
函数的变量的值先从自身作用域下找,符合之前学的声明和覆盖现象,找不到呢,就向自身函数的上层去找,上层就是自己声明的那个层级或者更高。
var a =1 //全局
function fn1(){
function fn2(){
console.log(a)
} //输出a 的值,但在fn2()中没声明,所以从这个函数的上层找,在上层fn1()中a=2,得出2。
function fn3() {
var a = 4
fn2( )
} // 这里要的是fn2()的值,往上看。
var a = 2
return fn3 //fn1()返回值是fn3的值
}
var fn = fn1( )
fn( ) //fn = fn1(),所以为(fn1( ))( )。输出的应该是fn1()的值,也就是2。
var a =1
function fn1( ) {
function fn3( ) {
var a = 4
fn2( ) //fn3要的是fn2的值,看fn2。
}
var a = 2
return fn3 // fn1返回值为fn3的值,看fn3。
}
function fn2() {
console.log(a) //输出a,在fn2的上层找a值,为1
}
var fn =fn1()
fn() //输出为fn1()的运行值
这里还有一个点,调用一个函数,一函数里return另一个函数,可以避免这两个函数里的数据被js的垃圾处理机制给清除了。还有不光找变量的顺讯是从内部到自身上层,return的函数也要如此,先内部,再外部。
作用域链
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- \如需转载请注明来源 1.作用域 作用域声明提前:1 带var的和函数不管位置在哪里,在作用域中都会被提到最前面进...