关于作用域链

何为作用域

任何编程语言都有作用域的概念,简单来说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。

js的作用域是靠函数来形成的,也就是说一个函数的变量在函数外不可以访问。

1. 全局作用域

任何地方都能访问到的对象拥有全局作用域。

  • 函数外面定义的变量拥有全局作用域

var n = 2;
function fn() {
var a = 1;
return a;
}

console.log(fn()); //1
console.log(n); //2
console.log(a); //报错error

  • 未定义直接赋值的变量自动声明为拥有全局作用域

var n = 2;
function fn() {
a = 1;
return a;
}

console.log(fn()); //1
console.log(n); //2
console.log(a); //1

2. 局部作用域

局部作用域一般只在固定的代码片段内可访问到,最常见的例如函数内部,所以在一些地方会把这种作用域成为函数作用域。

第一段代码中,a是函数内部声明并赋值,拥有局部作用域,只能带函数fn内部使用,在fn外部使用就会报错,这就是局部作用域的特性,外部无法访问。

作用域链

通俗地讲,当声明一个函数时,局部作用域一级一级向上包起来,就是作用域链。

当执行函数时,总是先从函数内部找寻局部变量

如果内部找不到(函数的局部作用域没有),则会向创建函数的作用域(声明函数的作用域)寻找,依次向上

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() //1

原因:先执行fn1,返回值是fn3的函数表达式,此时fn1的局部作用各变量已经赋值完毕;将fn3赋值给fn,即fn=function (){var a=4;fn2()};执行fn,调用执行fn2,fn2下没有定义a往上层作用域找,找到var a = 1,所以 console.log(a)等于1。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 函数在执行的过程中,先从自己内部找变量 如果找不到,再从创建当前函数所在的作用域去找,以此往上 范例 例1 分析:...
    crowdWu阅读 1,319评论 0 0
  • 要了解做作用域链,我们首先要搞清什么是作用域。 作用域(scope)指的是一段程序代码中所用到的名...
    猢狲宙斯阅读 3,728评论 0 0
  • 何为作用域 任何编程语言都有作用域的概念,简单来说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可...
    kzc爱吃梨阅读 773评论 0 0
  • 1.何为作用域 任何编程语言都有作用域的概念,简单来说,作用域就是变量与函数的可访问范围,即作用域控制着变量与函数...
    Kinderzhu阅读 910评论 0 0
  • 那些年,心里藏了一个人, 有时候欣喜若欢, 有时候痛苦难耐, 甚至愿意付出一切。 直到后来,有幸携手一起, 却发现...
    苏家小榭阅读 1,553评论 0 9