很多语言中都有块级作用域,但JS没有,它使用var声明变量,以function来划分作用域,大括号“{}” 却限定不了var的作用域。用var声明的变量具有变量提升(declaration hoisting)的效果。
ES6里增加了一个let,可以在{}, if, for里声明。用法同var,但作用域限定在块级,let声明的变量不存在变量提升。
示例1: 块级作用域 if
function getVal(boo) { if (boo) { var val = 'red' // ... return val } else { // 这里可以访问 val return null } // 这里也可以访问 val }
变量val在if块里声明的,但在else块和if外都可以访问到val。
把var换成let,就变成这样了
function getVal(boo) { if (boo) { let val = 'red' // ... return val } else { // 这里访问不到 val return null } // 这里也访问不到 val }
示例2: 块级作用域 for
function func(arr) { for (var i = 0; i < arr.length; i++) { // i ... } // 这里也可以访问到i }
变量i在for块里声明的,但在for外也能访问到。
把var换成let,for外就访问不了i
function func(arr) { for (let i = 0; i < arr.length; i++) { // i ... } // 这里访问不到i }
示例3: 变量提升(先使用后声明)
function func() { // val先使用后声明,不报错 alert(val) // undefined var val; }
变量val先使用后声明,输出undefined,也不报错。
把var换成let,就报错了
function func() { // val先使用后声明,报语法错 alert(val) let val; }
示例4: 变量提升(先判断后声明)
function func() { if (typeof val == 'undefined') { // ... } var val = '' }
使用typeof判断时也可以再var语句的前面
但把var换成let,if处报语法错
function func() { if (typeof val == 'undefined') { // ... } let val = ''; }
ES6规定,如果代码块中存在let,这个区块从一开始就形成了封闭作用域。凡是在声明之前就使用,就会报错。即在代码块内,在let声明之前使用变量都是不可用的。语法上有个术语叫“暂时性死区”(temporal dead zone),简称TDZ。当然TDZ并没有出现在ES规范里,它只是用来形象的描述。
let的注意事项
1. 不能重复声明
// var和let重复声明 var name = 'Jack'; let name = 'John'; // 两个let重复声明 let age = 24; let age = 30;
执行时报语法错
2. 有了let后,匿名函数自执行就可以去掉了
// 匿名函数写法 (function () { var jQuery = function() {}; // ... window.$ = jQuery })(); // 块级作用域写法 { let jQuery = function() {}; // ... window.$ = jQuery; }
以上所述就是本文的全部内容了,希望大家能够喜欢。
问题内容: 当我在node.js中键入时,我得到了。 如果没有关键字,则通过(=> 15)。它可以在Chrome控制台中运行(带有和不带有关键字)。 问题答案: 使用时它在Node中不起作用,因为它是 当前模块 的 本地变量 。您应该直接引用它:。 不输入时,发生的事情现在 是整个Node进程中的全局变量 。 在Chrome浏览器(或其他任何浏览器中-我不确定oldIE …),无论您是否在示例中使
问题内容: Java编译器如何处理以下开关块?“ b”变量的范围是什么? 注意,“ b”变量仅在switch语句的第一个分支中声明。尝试在第二个分支中声明它也会导致“重复的局部变量”编译错误。 注意:以上代码使用Java 1.6编译器进行编译。 问题答案: 与通常一样,范围由和分隔。
在函数体内部, 局部变量的 优先级别高于 同名的全局变量。如果函数外部和内部均有没有使用关键字var声明的同名变量,那么这个变量将被修改为函数内部的那个变量。 a = "Tom"; function curr() { a = "Bob"; return a; } var b = curr();//调用函数curr console.log(a); //Bob console.lo
问题内容: 如何在简短的变量声明中从其他块中重新声明变量? 关于此问题有很长的话题,但现在我很感兴趣如何解决此问题。 问题答案: 简短的变量声明的Go规范很明确: 短变量声明可以重新声明变量,只要它们最初是在同一块中以相同类型声明的,并且至少一个非空变量是新变量。 因此,在简短的变量声明中,您无法重新声明最初在其他块中声明的变量。 这是一个如何通过在内部块中声明局部变量()并将其()分配给在外部块
我得到奇怪的构建错误在我的角应用程序。有人能指出我做错了什么吗?我试图使用ADAL. js角包集成Azure AD身份验证。我使用为此。 cli命令: 节点模块/@angular/core/src/render3/ng_dev_模式中出错。d、 ts(9,11):错误TS2451:无法重新声明块作用域变量“ngDevMode”。node_modules/adal-angular5/node_mod
ES5中的函数本质上是可以在外面“看到”,但不能进入的容器。 在ES6中,var仍然以这种方式工作,使用函数作为容器,但有两种新的方法来声明变量:和let。 const和let使用{和}块作为容器,故称为“块作用域”。 块作用域在循环期间非常有用。 考虑以下代码: var i; for (i = 0; i < 10; i += 1) { var j = i; let k = i; } co
let和const是JavaScript里相对较新的变量声明方式。 像我们之前提到过的,let在很多方面与var是相似的,但是可以帮助大家避免在JavaScript里常见一些问题。 const是对let的一个增强,它能阻止对一个变量再次赋值。 因为TypeScript是JavaScript的超集,所以它本身就支持let和const。 下面我们会详细说明这些新的声明方式以及为什么推荐使用它们来代替v
本文向大家介绍JavaScript 变量、作用域及内存,包括了JavaScript 变量、作用域及内存的使用技巧和注意事项,需要的朋友参考一下 JS变量是松散型的(不强制类型)本质,决定了它只是在特定时间用于保存特定值的一个名字而已; 由于不存在定义某个变量必须要保存何种数据类型值的规则,变量的值及其数据类型可以在脚本的生命周期内改变; 一 变量及作用域 1.基本类型和引用类型 // JS变量包含