作用域 - 如何简单解释javascript中的scope chain?
天蓬老师
天蓬老师 2017-04-11 09:44:36
[JavaScript讨论组]

看了一些资料还是不太理解,有没有简单通俗一点的解释。

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回复(4)
巴扎黑

通俗的解释:

  1. 想象一下每个函数执行的时候,都会在背地里建立一个对象V。函数内定义的所有局部变量(包括函数参数)都放在这个对象上,作为这个对象的属性。就是说我们访问函数的局部变量时,实际上就是访问的对象V的一个属性而已。

  2. 这个对象V经常被叫做变量对象,顾名思义就是存放变量的对象。

  3. 每个函数在运行时都会自动建立一个变量对象V。而且内部函数的变量对象里面有一个指针指向外部函数的变量对象。

  4. 假设由于这个指针的存在,导致若干个嵌套了N层的函数在运转时形成了一个链表结构。这个链表经常被叫做作用域链

注:

  1. 注意变量对象和作用域链都是运行时概念。而且是JS引擎的内部机制,从代码的角度是不可见的。

  2. 如果看到这里你还不能彻底明白,那么你应该去看一下数据结构中的链表那一节了。

怪我咯

反复看这系列文章,反复看几遍
http://www.cnblogs.com/TomXu/archive/2012/01/18/2312463.html

迷茫

一句话总结:

scope chain = 变量对象 + [scope chain];

变量对象就是当前执行的函数,[scope chain]是这个变量对象定义时所处的作用域链。

伊谢尔伦

这样的情况不仅仅是js出现过,在python里面也同样出现过。
Key:对象的方法返回的对象还可以执行方法。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号