JS 【详解】作用域

简介: JS 【详解】作用域

作用域即变量/函数可以被访问的区域。

全局作用域

{} 和函数外的区域为全局作用域。

  • 全局作用域中的声明的变量是全局变量,在页面的任意的部分都可以访问。
  • 全局作用域中无法访问函数作用域的变量
  • 全局作用域在页面打开时创建,在页面关闭时销毁。
  • 全局作用域中有一个全局对象window,它代表的是一个浏览器的窗口,由浏览器创建,可以直接使用,全局变量是window对象的属性,函数是window对象的方法。
function foo() {
    var a = b = 100; // 连续赋值
}

foo();

console.log(window.b); // 打印 100 
console.log(window.a); // 打印 undefined 
console.log(a); // 报错 Uncaught ReferenceError: a is not defined

var a = b = 100 这行连续赋值的代码等价于 var a = (b = 100),其执行顺序是:

  1. 先把 100 赋值给 b;
  2. 再声明变量 a
  3. 再把 b 的值赋值给 a
  • b 是未经声明的变量就被赋值了,属于 window.b;
  • a 的作用域仅限于 foo() 函数内部,不属于 window;

块作用域

{} 中为块作用域

  • 变量只在代码块中有效;

ES5本身不提供块级作用域,通常使用立即调用函数表达式实现

(function () {
  var block_scoped=0;
}());
console.log(block_scoped); //引用错误

ES6中,使用 let 和 const 实现块级作用域

let a =1
if(a===1) {
  let b = 2
}
console.log(b); // Uncaught ReferenceError: b is not defined

函数作用域

函数内的区域为函数作用域(即 function 中 { } 内的部分)

函数作用域的原理

执行期上下文:当函数执行时,会创建一个执行期上下文的内部对象。每调用一次函数,就会创建一个新的上下文对象,他们之间是相互独立的。当函数执行完毕,它所产生的执行期上下文会被销毁。


在函数作用域操作一个变量时,它会先在自身作用域中寻找,如果有就直接使用(就近原则)。如果没有则向上一级作用域中寻找,直到找到全局作用域;如果全局作用域中依然没有找到,则会报错ReferenceError。

函数作用域的特点

  • 函数作用域中可以访问到全局作用域的变量,如window.a(全局作用域和函数作用域都定义了变量a时)
  • 全局作用域无法访问函数内定义的变量
  • 函数中,使用var关键字声明的变量,会在函数中所有的代码执行之前被声明
  • 函数中,没有var声明的变量都是全局变量,而且并不会提前声明。
  • 函数中,函数声明也会在函数中所有的代码执行之前执行
    var a = 1;

    function foo() {
        console.log(a);
        a = 2;     // 此处的a相当于window.a
    }

    foo(); // 打印结果是1
    console.log(a);   //打印结果是2

定义形参就相当于在函数作用域中声明了变量。

    function fun6(e) { // 这个函数中,因为有了形参 e,此时就相当于在函数内部的第一行代码里,写了 var e;
        console.log(e);
    }

    fun6();  //打印结果为 undefined
    fun6(123);//打印结果为123

模块作用域

ES6新增语法,每个js文件都是一个模块,每个模块中的区域即模块作用域,其他文件要使用模块中的变量/函数,必须对外导出模块中的变量/函数,并在目标文件中引入。

图解—JS调用栈

目录
打赏
0
0
0
0
62
分享
相关文章
js的作用域作用域链
【10月更文挑战第29天】理解JavaScript的作用域和作用域链对于正确理解变量的访问和生命周期、避免变量命名冲突以及编写高质量的JavaScript代码都具有重要意义。在实际开发中,需要合理地利用作用域和作用域链来组织代码结构,提高代码的可读性和可维护性。
浅谈js作用域
浅谈js作用域
40 0
[JS]作用域的“生产者”——词法作用域
本文介绍了JavaScript中的作用域模型与作用域,包括词法作用域和动态作用域的区别,以及全局作用域、函数作用域和块级作用域的特点。通过具体示例详细解析了变量提升、块级作用域中的暂时性死区等问题,并探讨了如何在循环中使用`var`和`let`的不同效果。最后,介绍了两种可以“欺骗”词法作用域的方法:`eval(str)`和`with(obj)`。文章结合了多位博主的总结,帮助读者更快速、便捷地掌握这些知识点。
38 2
[JS]作用域的“生产者”——词法作用域
CSS 变量的作用域和 JavaScript 变量的作用域有什么不同?
【10月更文挑战第28天】CSS变量和JavaScript变量虽然都有各自的作用域概念,但由于它们所属的语言和应用场景不同,其作用域的定义、范围、覆盖规则以及与其他语言特性的交互方式等方面都存在明显的差异。理解这些差异有助于更好地在Web开发中分别运用它们来实现预期的页面效果和功能逻辑。
如何在 JavaScript 中实现块级作用域?
【10月更文挑战第29天】通过使用 `let`、`const` 关键字、立即执行函数表达式以及模块模式等方法,可以在JavaScript中有效地实现块级作用域,更好地控制变量的生命周期和访问权限,提高代码的可维护性和可读性。
javascript的作用域
【10月更文挑战第19天javascript的作用域
JavaScript 作用域
JavaScript 作用域是指程序中可访问的变量、对象和函数的集合。它分为函数作用域和局部作用域。函数作用域内的变量仅在函数内部可见,而全局作用域的变量在整个网页中均可访问。局部变量在函数执行完毕后会被销毁,而全局变量则在整个脚本生命周期中都存在。未使用 `var` 关键字声明的变量默认为全局变量。
JavaScript基础知识-作用域(action scope)
关于JavaScript基础知识中作用域的介绍。
67 1
JavaScript基础知识-作用域(action scope)