var

您所在的位置:网站首页 js中get和set关键字作用 var

var

2024-07-05 11:15| 来源: 网络整理| 查看: 265

即使是在严格模式下,使用 var 重复声明变量不会触发错误,变量的值也不会丢失,除非新的声明有初始化器。

jsvar a = 1; var a = 2; console.log(a); // 2 var a; console.log(a); // 2; not undefined

var 可以与 function 在同一作用域中声明同名变量。在这种情况下,var 声明的初始化器总是会覆盖函数的值,而无论它们的相对位置如何。这是因为函数声明会提升到作用域的顶部,而初始化器会在其后才被求值,因此会覆盖函数的值。

jsvar a = 1; function a() {} console.log(a); // 1

var 不能与 let、const、class 或 import 在同一作用域中声明同名变量。

jsvar a = 1; let a = 2; // SyntaxError: Identifier 'a' has already been declared

因为 var 声明作用域不限于块,所以这也适用于以下情况:

jslet a = 1; { var a = 1; // SyntaxError: Identifier 'a' has already been declared }

它不适用于以下情况,其中 let 位于 var 的子作用域中,而不是同一作用域:

jsvar a = 1; { let a = 2; }

函数体内的 var 声明可以与函数参数同名。

jsfunction foo(a) { var a = 1; console.log(a); } foo(2); // 输出 1

catch 块内的 var 声明可以与 catch 绑定的标识符同名,但只有当 catch 绑定的是一个简单标识符,而不是解构模式时才可以。这是一种已弃用的语法,你不应该依赖它。在这种情况下,声明会被提升到 catch 块外部,但在 catch 块内的任何赋值都不会在外部可见。

jstry { throw 1; } catch (e) { var e = 2; // 有效 } console.log(e); // undefined


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3