html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

浅谈JavaScript中定义变量时有无var声明的区别_javascript技巧_

[ ] 已经帮助:人解决问题

前段时间回答了一个关于定义变量时使用关键字var与否的区别,总结回顾一下。Z6vHTML5中文学习网 - HTML5先行者学习网

1.在函数作用域内 加var定义的变量是局部变量,不加var定义的就成了全局变量。Z6vHTML5中文学习网 - HTML5先行者学习网
使用var定义:Z6vHTML5中文学习网 - HTML5先行者学习网

var a = 'hello World';function bb(){ var a = 'hello Bill'; console.log(a);  }bb()      //'hello Bill'console.log(a);  //'hello world'

不使用var定义:Z6vHTML5中文学习网 - HTML5先行者学习网

var a = 'hello World';function bb(){ a = 'hello Bill'; console.log(a);  }bb()      //'hello Bill'console.log(a);  //'hello Bill'

2.在全局作用域下,使用var定义的变量不可以delete,没有var 定义的变量可以delete.也就说明隐含全局变量严格来说不是真正的变量,而是全局对象的属性,因为属性可以通过delete删除,而变量不可以。Z6vHTML5中文学习网 - HTML5先行者学习网
Z6vHTML5中文学习网 - HTML5先行者学习网

3.使用var 定义变量还会提升变量声明,即Z6vHTML5中文学习网 - HTML5先行者学习网
使用var定义:Z6vHTML5中文学习网 - HTML5先行者学习网

function hh(){ console.log(a); var a = 'hello world';}hh()      //undefined

不使用var定义:Z6vHTML5中文学习网 - HTML5先行者学习网

function hh(){ console.log(a); a = 'hello world';}hh()      //'a is not defined'

这就是使用var定义的变量的声明提前。Z6vHTML5中文学习网 - HTML5先行者学习网
Z6vHTML5中文学习网 - HTML5先行者学习网

4.在ES5的'use strict'模式下,如果变量没有使用var定义,就会报错。Z6vHTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助