JavaScript 中的作用域和闭包是掌握这门语言的关键基础概念。它们是构造函数、工厂函数和立即执行函数表达式 (IIFE) 等核心机制背后的基石。
本文将通过实际示例讲解 JavaScript 的作用域,后续文章将深入探讨闭包。
作用域与词法作用域
作用域决定了变量在 JavaScript 程序中的可见性和可访问性。主要分为两种类型:
全局作用域局部作用域
全局作用域
全局作用域的变量在程序的任何位置都可访问。技术上讲,未在任何函数或代码块 ({}) 内声明的变量都属于全局作用域。
立即学习“Java免费学习笔记(深入)”;
局部作用域
局部作用域的变量仅在其声明的特定上下文中可用。技术上讲,在函数或代码块 ({}) 内声明的变量都属于局部作用域。
let x = 3; // x (全局作用域)function addxy() { let y = 5; // y (局部作用域) return x + y; // 返回 8,因为 x 在程序的任何位置都可用}
登录后复制
作用域的扩展
ECMAScript 作为 JavaScript 的标准化规范,确保了跨平台的一致性和互操作性。ES6 (ECMAScript 2015) 的一个重要更新是引入了 let 和 const 关键字。
ES6 之前,JavaScript 使用 var 关键字定义变量。var 声明的变量可以被重新赋值和重新声明,并且仅在函数内部具有局部作用域。let 和 const 则引入了块级作用域,这意味着变量仅在其声明的最近的代码块 ({}) 内可用。
示例:
function addxyz() { var x = 3; let y = 4; const z = 5; return x + y + z; // 12}// 这些语句将输出 undefined,因为 var, let, 和 const 变量在函数内部具有局部作用域。console.log(x);console.log(y);console.log(z);
登录后复制
let age = 10; // 全局变量if (age < 18) { let isMinor = true; // 块级作用域 console.log(isMinor); // true}console.log(isMinor); // 报错:isMinor 未定义
登录后复制
后续文章将讨论词法作用域和闭包。感谢阅读。
以上就是理解 JavaScript 中的作用域的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2642748.html