JS作用域链
JS作用域链
如题1
var a = 1
function fn1(){
function fn2(){
console.log(a)
}
function fn3(){
var a = 4
fn2()
}
var a = 2
return fn3
}
var fn = fn1()
fn() //输出多少
题中fn()输出为2
说明:fn1()执行到最后是fn2(),fn2()内部没有定义变量,所以从当前函数所在的作用域去找,即f1()中查找(fn2()为fn1()的内部函数),fn1()中a=2,所以输出为2. 题2
var a = 1
function fn1(){
function fn3(){
var a = 4
fn2()
}
var a = 2
return fn3
}
function fn2(){
console.log(a)
}
var fn = fn1()
fn() //输出多少
题中fn()输出为1
说明:执行fn1()后最终的调用函数为fn2(),而fn2()中没有定义a,所以从它所在的作用域寻找变量a,不难发现它的作用域是全局,全局变量a为1,所以结果输出为1. 题3:
var a = 1
function fn1(){function fn3(){
function fn2(){
console.log(a)
}
var afn2()
a = 4
}
var a = 2
return fn3
}
var fn = fn1()
fn() //输出多少
【JS作用域链】结果为:undefined
说明:执行结果为fn2(),它内部没有定义a,所以从它的作用域去寻找--即fn3(),因为a=4的赋值语句在fn2()后执行,所以此时a只是定义了还没有赋值,所以a为undefined. 总结:
- 函数在执行的过程中,先从自己内部找变量
- 如果找不到,再从创建当前函数所在的作用域去找, 以此往上
- 注意找的是变量的当前的状态
推荐阅读
- 画解算法(1.|画解算法:1. 两数之和)
- 标签、语法规范、内联框架、超链接、CSS的编写位置、CSS语法、开发工具、块和内联、常用选择器、后代元素选择器、伪类、伪元素。
- 「#1-颜龙武」区块链的价值是什么()
- leetcode|leetcode 92. 反转链表 II
- BNC公链|BNC公链 | Eth2.0测试网Topaz已质押超100万枚ETH
- 【#2-戴栋】区块链可以提升哪些商业上的效率改进
- 父母链接八~未了情结
- java|java 常用知识点链接
- cocosbcx白皮书解读(一)|cocosbcx白皮书解读(一)| 区块链如何统一开发者、发行商、用户之间的利益
- 第六章|第六章 Sleuth--链路追踪