手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >浅谈JavaScript中定义变量时有无var声明的区别
浅谈JavaScript中定义变量时有无var声明的区别
摘要:前段时间回答了一个关于定义变量时使用关键字var与否的区别,总结回顾一下。1.在函数作用域内加var定义的变量是局部变量,不加var定义的就...

前段时间回答了一个关于定义变量时使用关键字var与否的区别,总结回顾一下。

1.在函数作用域内 加var定义的变量是局部变量,不加var定义的就成了全局变量。

使用var定义:

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

不使用var定义:

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删除,而变量不可以。

3.使用var 定义变量还会提升变量声明,即

使用var定义:

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

不使用var定义:

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

这就是使用var定义的变量的声明提前。

4.在ES5的'use strict'模式下,如果变量没有使用var定义,就会报错。

【浅谈JavaScript中定义变量时有无var声明的区别】相关文章:

JavaScript中的私有成员

实现高性能JavaScript之执行与加载

浅谈javascript中for in 和 for each in的区别

javascript自定义右键弹出菜单实现方法

javascript实现table表格隔行变色的方法

浅谈javascript中的闭包

JavaScript中的this机制

详解JavaScript中的表单验证

JavaScript中reduce()方法的使用详解

JavaScipt中Function()函数的使用教程

精品推荐
分类导航