资讯专栏INFORMATION COLUMN

理解javaScript变量、作用域链

KevinYan / 3044人阅读

摘要:作用域链的用途,是保证对执行环境有权访问的所有变量和函数的有序访问。当前的执行环境就是作用域的最前端,标识符解析是沿着作用域链最前端向后回溯,直到找到标志符当某个函数被调用时,会创建一个执行环境及相应的作用域链。

变量
由于JavaScript变量松散类型的本质,决定了它只是在特定时间用于保存特定值的一个名字而已。变量分为基础类型值引用类型值
基本类型值指的是简单的数据段(Undefined、Null、Boolean、Number、String 和 symbol),而引用类型值指那些可能由多个值构成的对象。

引用类型的值是保存在内存中的对象。与其他语言不同,JavaScript 不允许直接访问内存中的位置, 也就是说不能直接操作对象的内存空间。在操作对象时,实际上是在操作对象的引用而不是实际的对象。 为此,引用类型的值是按引用访问的
var obj1 = new Object();

var obj2 = obj1;
obj1.name = "Nicholas";
alert(obj2.name);  //"Nicholas"

作用域链
1.执行环境
执行环境(execution context,为简单起见,有时也称为“环境”)定义了变量或函数有权访问的其他数据,决定了它们各自的行为。
每个函数都有自己的执行环境。当执行流进入一个函数时,函数的环境就会被推入一个环境栈中。 而在函数执行之后,栈将其环境弹出,把控制权返回给之前的执行环境。ECMAScript 程序中的执行流 正是由这个方便的机制控制着。
全局执行环境是最外层环境,web开发中通常认为是window;某个执行环境中所有代码执行完毕后,该环境将被销毁,保存在其中的变量和函数也将同时被销毁
2.当代码在一个环境中执行时,会创建变量对象的一个作用域链(scope chain)。作用域链的用途,是保证对执行环境有权访问的所有变量和函数的有序访问。当前的执行环境就是作用域的最前端,标识符解析是沿着作用域链最前端向后回溯,直到找到标志符
3.当某个函数被调用时,会创建一个执行环境(execution context)及相应的作用域链。 然后,使用 arguments 和其他命名参数的值来初始化函数的活动对象(activation object)。
闭包
闭包是指有权访问另一个函数作用域中的变量的函数。创建闭包的常见方式,就是在一个函数内部创建另一个函数。
无论什么时候在函数中访问一个变量时,就会从作用域链中搜索具有相应名字的变量。一般来讲, 当函数执行完毕后,局部活动对象就会被销毁,内存中仅保存全局作用域(全局执行环境的变量对象)。 但是,闭包的情况又有所不同。
外部函数执行结束后,执行环境就会在作用域链中销毁,但是由于闭包函数的局部作用域链仍在使用其活动对象,所以闭包函数被销毁时外部活动环境才能被销毁。
由于闭包会携带包含它的函数的作用域,因此会比其他函数占用更多的内存。

this
1.(默认绑定)普通函数调用;this指向window

在严格模式下(strict mode),全局对象将无法使用默认绑定,即执行会报undefined的错误

2.(隐式绑定)作为对象方法调用;this指向调用对象

3.作为构造函数调用,this 指代实例对象

4.call() 和 apply()、bind()
主要是通过改变对象的prototype关联对象。具体使用上,可以通过这两个方法call(…)或apply(…)来实现(大多数函数及自己创建的函数默认都提供这两个方法)call与apply是同样的作用,区别只是其他参数的设置上,
apply:调用一个对象的一个方法,用另一个对象替换当前对象。例如:B.apply(A, arguments);即A对象应用B对象的方法。

call:调用一个对象的一个方法,用另一个对象替换当前对象。例如:B.call(A, args1,args2);即A对象调用B对象的方法。

bind:call和apply都是改变上下文中的this并立即执行这个函数,bind方法可以让对应的函数想什么时候调就什么时候调用,并且可以将参数在执行的时候添加,这是它们的区别。
bind也可以有多个参数,并且参数可以执行的时候再次添加,但是要注意的是,参数是按照形参的顺序进行的。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/101800.html

相关文章

  • 谈谈javascript语法里一些难点问题(二)

    摘要:讲作用域链首先要从作用域讲起,下面是百度百科里对作用域的定义作用域在许多程序设计语言中非常重要。原文出处谈谈语法里一些难点问题二 3) 作用域链相关的问题 作用域链是javascript语言里非常红的概念,很多学习和使用javascript语言的程序员都知道作用域链是理解javascript里很重要的一些概念的关键,这些概念包括this指针,闭包等等,它非常红的另一个重要原因就...

    Enlightenment 评论0 收藏0
  • 还是不明白JavaScript - 执行环境、作用域、作用域链、闭包吗?

    摘要:所以,全局执行环境的变量对象始终都是作用域链中的最后一个对象。讲到这里,可能你已经对执行环境执行环境对象变量对象作用域作用域链的理解已经他们之间的关系有了一个较清晰的认识。 JavaScript中的执行环境、作用域、作用域链、闭包一直是一个非常有意思的话题,很多博主和大神都分享过相关的文章。这些知识点不仅比较抽象,不易理解,更重要的是与这些知识点相关的问题在面试中高频出现。之前我也看过...

    jlanglang 评论0 收藏0
  • 理解JavaScript中的作用域和作用域链

    摘要:示例当一个函数创建后,它的作用域链会被创建此函数的作用域中可访问的数据对象填充。每一个运行期上下文都和一个作用域链关联。此时,作用域链中函数的所有局部变量所在的作用域对象会被推后,访问代价变高了。 作用域 作用域就是变量与函数的可访问范围,即作用域控制着变量与函数的可见性和生命周期。在JavaScript中,变量的作用域有全局作用域和局部作用域两种。 作用域链 函数对象有一个内部属性[...

    XanaHopper 评论0 收藏0
  • 我所认识的JavaScript作用域链和原型链

    摘要:为了防止之后自己又开始模糊,所以自己来总结一下中关于作用域链和原型链的知识,并将二者相比较看待进一步加深理解。因此我们发现当多个作用域相互嵌套的时候,就形成了作用域链。原型链原型说完了作用域链,我们来讲讲原型链。   毕业也整整一年了,看着很多学弟都毕业了,忽然心中颇有感慨,时间一去不复还呀。记得从去年这个时候接触到JavaScript,从一开始就很喜欢这门语言,当时迷迷糊糊看完了《J...

    Bmob 评论0 收藏0
  • JavaScript作用域链与闭包的理解

    摘要:作用域是最重要的概念之一,想要学好就需要理解作用域和作用域链的工作原理。脚本错误脚本错误由此可以引发作用域链的概念在中,函数也是对象,实际上,里一切都是对象。当一个函数创建后,它的作用域链会被创建此函数的作用域中可访问的数据对象填充。 作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域 链的工作原理。 1. 全局作...

    tianhang 评论0 收藏0
  • JavaScript作用域链与闭包的理解

    摘要:作用域是最重要的概念之一,想要学好就需要理解作用域和作用域链的工作原理。脚本错误脚本错误由此可以引发作用域链的概念在中,函数也是对象,实际上,里一切都是对象。当一个函数创建后,它的作用域链会被创建此函数的作用域中可访问的数据对象填充。 作用域是JavaScript最重要的概念之一,想要学好JavaScript就需要理解JavaScript作用域和作用域 链的工作原理。 1. 全局作...

    darcrand 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<