美文网首页大前端技术文章
不使用var定义的变量

不使用var定义的变量

作者: 千锋HTML5学院 | 来源:发表于2020-09-08 10:11 被阅读0次

js变量

JavaScript声明变量可以用var声明,也可以不用var声明,两种声明变量的方式有什么区别呢?

注:此处暂不讨论 ES6 中的 letconst

JavaScript变量分为 局部变量全局变量

简单理解:

在函数中用var声明的变量即为 局部变量
在函数外用var声明的变量即为 全局变量

但是,这里说的函数中和函数外也不是绝对的,看以下代码及分析:

// demo1
var a = 123; // 全局变量
var b = 456; // 全局变量
console.log(a); // 123
console.log(b); // 456
console.log(window.a); // 123
console.log(window.b); // 456
console.log(window); // 打印结果如下图

demo1 可以看到,不管是直接访问变量 a b 或是访问window对象的属性 a b 都能输出相同结果

// demo2
var a = 123; // 使用var声明
b = 456; // 不使用var声明
console.log(a); // 123
console.log(b); // 456
console.log(window.a); // 123
console.log(window.b); // 456
console.log(window); // 打印结果如下图

demo2 打印结果和上面 demo1 "相同"

另外,使用var声明变量也叫显示声明,不用var声明变量也叫隐式声明

通过上面demo1和demo2我们可以得到以下结论:

在函数外,不管是使用var声明变量,还是不用var声明变量,它们都是全局变量。
全局变量其实是在window对象中添加属性并赋值。

继续看demo...

// demo3
function fn() {
 var a = 123;
 var b = 456;
 console.log(a); // 123
 console.log(b); // 456
 console.log(window.a); // undefined
 console.log(window.b); // undefined
}
fn();

demo3 直接访问变量 a b 可以正常输出结果,访问window对象的属性 a b结果为 undefined

// demo4
function fn() {
 var a = 123; // 使用var声明
 b = 456; // 不使用var声明
 console.log(a); // 123
 console.log(b); // 456
 console.log(window.a); // undefined
 console.log(window.b); // 456
}
fn();
console.log(b); // 456
console.log(window); // 结果如下图

demo4 打印结果可以看到:

1.直接访问变量 a b 可以正常输出结果
2.访问window对象的属性 a 结果为 undefined,属性 b 可以正常输出结果
3.在window对象中有属性 b,没有属性 a

是否发现了什么...?

通过上面 demo3 和 demo4 我们可以得到以下结论:

在函数中,使用var声明的变量为局部变量,不用var声明的变量为全局变量

用var声明变量和不用var声明变量的区别之一:

在函数外,用var声明的变量为全局变量,不用var声明的变量为全局变量
在函数中,用var声明的变量为局部变量,不用var声明的变量为全局变量

除了作用域的区别以外

// demo5
var a = 123; // 使用var声明
b = 456; // 不使用var声明
console.log(window.a); // 123
console.log(window.b); // 456
console.log(delete a); // false
console.log(delete b); // true
console.log(window.a); // 123
console.log(window.b); // undefined

注:delete 用来删除对象的属性,如果是不可配置的属性返回false,其他情况返回true
demo5 可以看到,变量 a b 都是全局变量,同为window对象的其中一个属性,a 不可以删除,b 可以删除

用var声明变量和不用var声明变量的区别之二:

同为全局变量,同为window对象的其中一个属性,用var声明的变量不可以删除,不用var声明的变量可以删除!

对象属性是否可删除, 其实是可以配置的

Object.getOwnPropertyDescriptor(); 方法返回某个对象属性的描述对象
Object.defineProperty(); 方法会直接在某个对象上定义一个新属性,或者修改一个已经存在的属性, 并返回这个对象

// demo6
var a = 123; // 使用var声明
b = 456; // 不使用var声明
console.log(Object.getOwnPropertyDescriptor(window, 'a'));
// {value: 123, writable: true, enumerable: true, configurable: false}
console.log(Object.getOwnPropertyDescriptor(window, 'b'));
// {value: 456, writable: true, enumerable: true, configurable: true}

demo6 我们可以看到window对象的属性 a 和 b 的描述对象包含以下信息:

value 属性的值
writable 属性是否可读写
enumerable 属性是否可枚举
configurable 属性是否可配置(删除)
属性 a 和 b 的描述对象区别在于 是否可配置 这个特性
属性 a 为 configurable: false 不可配置
属性 b 为 configurable: true 可配置

// demo7
var a = 123; // 使用var声明
b = 456; // 不使用var声明
Object.defineProperty(window, 'b', {configurable: false});
console.log(delete a); // false
console.log(delete b); // false
console.log(window.a); // 123
console.log(window.b); // 456
console.log(Object.getOwnPropertyDescriptor(window, 'b'));
// {value: 456, writable: true, enumerable: true, configurable: false}

通过 demo6 和 demo7 我们得到上面那个问题的答案:

对象的属性是否可删除,取决于描述对象的配置属性configurable
用var声明的变量默认不可删除,不用var声明的变量默认带可删除。

相关文章

  • var与let

    1、var定义变量 1.1 不指定类型定义变量 //定义变量(不指定类型变量),使用var关键字var x = 1...

  • javascript数据类型和运算符

    1)定义和赋值变量:var 变量名=值;注意:1)使用var关键词定义变量,var可以省略,但是不建议省略var2...

  • Dart常量和变量

    Dart是弱类型语言,在定义变量时可以不指定具体的变量类型,类似JavaScript。使用var定义变量;可以不指...

  • JavaScript基本语法笔记

    变量 使用关键字var来定义变量,js的变量是弱类型,var不写也可以 运算符 算术运算符 var a = 317...

  • JS高级程序设计知识点记录(一)

    一、 变量使用 var 定义的变量,会成为该变量作用域中的局部变量。即,如果在函数中使用 var 定义了一个变量,...

  • dart 数据类型

    一、变量和常量 1.变量 var dart语言的变量定义与JavaScript定义变量一样的,使用var 关键字。...

  • 小程序中使用全局样式

    css 自定义属性 1.语法 --*来声明变量名 var(--*)来使用变量 css 自定义属性使用中,var()...

  • JS变量提升

    1、函数内未用var定义变量 在函数内部未使用var定义变量,此时变量为全局变量。 2、将变量申明(除赋值)提升 ...

  • JaveScript 基本语法的学习

    1. 变量 使用var来定义变量,例子如下var x = 2; var y = 3; var z = x+y; 变...

  • Swift初体验 变量&常量&元组

    一、变量和常量01 变量和常量的定义在swift中变量使用var来修饰,常量使用let来修饰,变量可以修改而常量不...

网友评论

    本文标题:不使用var定义的变量

    本文链接:https://www.haomeiwen.com/subject/dirdektx.html