荣耀|Web前端 - JS中作用域及作用域链的真面目
一、 作用域
1 定义
作用域是指在程序中定义变量的区域 , 该位置决定了变量的生命周期 。 简言之作用域就是变量与函数的可访问范围 , 即作用域控制着变量和函数的可见性和生命周期 。
2 分类
在ES6阶段之前 , 作用域分为两种:全局作用域和函数作用域;进行ES6之后 , 作用域分为:全局作用域、函数作用域和块级作用域 。
1. 全局作用域
在该作用域中的对象在代码的任何地方都能访问 , 其生命周期伴随着页面的生命周期 。 例如以下内容均在全局作用域中 。
(1)window上的属性(在浏览器中)
console.log(window.location.href); // 页面地址
(2)最外层的函数
function testFun() {
console.log('testFun');
testFun();
(3)最外层定义的变量
let val1 = 10;
const val2 = 20;
var val3 = 30;
(4)未定义直接赋值的变量
val4 = 40;
(5)js规定的全局对象的属性 , 三个值(Infinity、NaN、undefined)、九个函数(parseInt、parseFloat、decodeURI、encodeURI……)、一些构造器(Date、Array等)、四个用于当做命名空间的对象(Atomics、JSON、Math、Reflect) 。
Math.sin(Math.PI / 2);;
const date = new Date();
2. 函数作用域
在函数内部定义的变量或者函数 , 并且定义的变量或者函数只能在函数内部被访问 。 在函数执行结束之后 , 函数内部定义的变量会被销毁 。
function test() {
var val1 = 10;
function fun1() {
console.log('fun1');
console.log(val1); // 10
fun1(); // fun1
test();
// console.log(val1); // val1 is not defined
// fun1(); // fun1 is not defined
块级作用域
在ES6阶段 , 出现了块的概念 , 新增了块级作用域 , 同时新增了let、const命令 。 块级作用域简言之就是使用一对大括号{包裹的一段代码 , 通过单独的大括号、if块、while块、for块、try/catch/finallyd等都会产生块级作用域 。 (对于let和const在块级作用域的特征可见前端百题斩【002】)
// 单一括号包括的块
{
// if语句
if (flag) {
// for语句
for (let i = 0; i < 10; i++) {
// ……
二、 作用域链
1 定义
在每个执行上下文的变量环境中 , 都包含一个外部引用(成为outer) , 用来指向外部的指向上下文 。 当在查找一个变量的时候 , 如果在当前的变量环境中没有找到 , js引擎会继续在outer所指向的执行上下文中查找 , 把这个查找的链条称为作用域链 。 (作用域链可以理解为一组对象列表 , 包含 父级和自身的变量对象 , 因此我们便能通过作用域链访问到父级里声明的变量或者函数 。 )
2 组成
作用域链由两部分组成 , 分别是[[scope
属性和AO 。
[[scope
属性:指向父级变量对象和作用域链 , 也就是包含了父级的[[scope
和AO
AO:自身活动对象 , 也就是该执行上下文中的变量对象 。
扩展:如此 [[scope
包含[[scope
, 便自上而下形成一条 链式作用域 。
3 查找规则
从当前的执行作用域开始查找变量;
如果在当前作用域中找不到该变量 , 则向上一级进行查找;
继续向上一层查找 , 直到最外层的全局作用域 。
4 实战
下面用一个简单的例子来演示该作用域链 , 以进一步理解作用域链 。
var val1 = 10;
function fun1() {
var val2 = 20;
function fun2() {
var val3 = 30;
console.log(val1 + val2 + val3);
fun2();
fun1();
【荣耀|Web前端 - JS中作用域及作用域链的真面目】
- 荣耀|今年过节不乱跑,荣耀智慧屏1499起,和年夜饭一样真香
- 荣耀magic3|实力旗舰!5200mAh+4nm+1TB,荣耀新机亮剑
- 小米12|自研动态性能调度!小姐姐实测小米12 Pro《王者荣耀》:功耗下降20%
- 小米科技|我用的红米10x和小米10pro手机信号,比一台华为p30,一台荣耀v20强
- javascript|Web前端培训:什么是 MEAN Stack?
- 荣耀MagicV能否成折叠屏手机新拐点?带你体验
- 华为Nova|无限套娃!华为nova 9 SE入网,外观、配置与荣耀50 SE一致
- 尴尬了!鸿星尔克与王者荣耀联名宣发翻车,两次发文皆未得到回应
- 中新网北京1月15日电 “既是大屏|荣耀Magic V能否成折叠屏手机新拐点?带你体验
- 在前不久举行的荣耀新品发布会上|荣耀首款折叠屏手表gs3今日开售售价1299元起