javascript中使用var和不使用var定义变量的区别
2018-02-27 16:45
543 查看
听人问起这个问题,自己一时答不上来,便查找资料总结了一下。
JavaScript中使用var和不使用var定义变量主要有两个区别:
1.
var a = 1;
function aaa(){
b = 2;
};
console.log(a);//1
//console.log(b);//b if not defined
aaa();
console.log(b);//2代码分析:
1)a为全局变量,值为1;
2)在aaa函数执行前,全局变量并没有b这个变量,此时输出变量b就是未定义;
3)在aaa函数执行后,b = 2执行后,在全局中创建了一个变量b并为其赋值为2;
4)此时再输出b自然就为2了;
此代码中很重要的一点是:b = 2在aaa函数里面,只有在执行一次aaa函数时,才会创建全局变量b并赋值,否则全局变量里就没有b;除此之外这样定义全局变量的做法并不推荐,在变量声明提升时,并不会出现全局变量b,只有在执行b外部函数时才会出现。给未经声明的变量赋值在严格模式下回导致抛出ReferenceError错误。
2.var a = 1;
b = 2;
window.c = 3;
this.d = 4;
delete a;//false
delete b;//true
delete c;//true
delete d;//true代码分析:
声明全局变量,都为window添加了一个属性,然而上述代码中的四种形式,只有var声明的全局变量才不能被delete删除。这也是var声明变量与不用var声明变量的一个区别。
JavaScript中使用var和不使用var定义变量主要有两个区别:
1.
var a = 1;
function aaa(){
b = 2;
};
console.log(a);//1
//console.log(b);//b if not defined
aaa();
console.log(b);//2代码分析:
1)a为全局变量,值为1;
2)在aaa函数执行前,全局变量并没有b这个变量,此时输出变量b就是未定义;
3)在aaa函数执行后,b = 2执行后,在全局中创建了一个变量b并为其赋值为2;
4)此时再输出b自然就为2了;
此代码中很重要的一点是:b = 2在aaa函数里面,只有在执行一次aaa函数时,才会创建全局变量b并赋值,否则全局变量里就没有b;除此之外这样定义全局变量的做法并不推荐,在变量声明提升时,并不会出现全局变量b,只有在执行b外部函数时才会出现。给未经声明的变量赋值在严格模式下回导致抛出ReferenceError错误。
2.var a = 1;
b = 2;
window.c = 3;
this.d = 4;
delete a;//false
delete b;//true
delete c;//true
delete d;//true代码分析:
声明全局变量,都为window添加了一个属性,然而上述代码中的四种形式,只有var声明的全局变量才不能被delete删除。这也是var声明变量与不用var声明变量的一个区别。
相关文章推荐
- javaScript中使用var和不是用var定义变量的区别
- javascript定义变量时带var与不带var的区别分析
- javascript定义全局变量的时候有var和没有var的区别
- javascript定义变量时有var和没有var的区别探讨
- javascript定义变量时,有var和没有var的区别
- javascript中是否使用var定义的区别,以及有名函数和匿名函数的区别。
- 不使用var定义变量和使用var的区别
- javascript定义变量时加var与不加var的区别
- JavaScript 中定义变量时有无var声明的区别
- javascript定义变量时带var与不带var的区别分析
- [js点滴]使用var定义变量和不使用var的本质区别
- javascript中使用var定义变量的预编译效果
- JavaScript中let和var定义变量的区别
- 浅谈 JavaScript 中定义变量时有无 var 声明的区别
- javascript定义变量时加var与不加var的区别
- 浅谈JavaScript中定义变量时有无var声明的区别
- javascript定义变量时加var与不加var的区别
- javascript定义变量时有var和没有var的区别探讨
- JavaScript定义变量是加var和不加var的区别
- javascript定义变量时有var和没有var的区别探讨