js中的var详解

var是js的一个关键字,它是用来声明变量的。

声明一个变量有两种方式:

第一种:var num=1。如果在方法中声明,则为局部变量;如果在全局中声明,则为全局变量

第二种:num=1。事实上这是对属性进行赋值操作。首先,它会尝试在当前作用域链(如果在方法中声明,则当前作用域代表全局作用域和方法局部作用域)中解析num,如果在任何当前作用域链中找到num,则会对num属性进行赋值,如果没有找到num,他会在全局对象(即当前作用域链的最顶层对象,如window对象)中创造num属性并赋值

注意!它并不是声明了一个全局变量,而是创建了一个全局对象的属性

由于变量声明自带不可删除属性,比较var num=1跟num=1,前者是变量声明,带不可删除属性,因此无法被删除;后者为全局变量的一个属性,因此可以从全局变量中删除。


变量提升


JavaScript引擎的工作方式是,先解析代码,获取所有被声明的变量,然后再一行一行的运行,这造成的结果,就是所有的变量的声明语句,都会被提升到代码的头部,这就叫做变量提升

示例:

    console.log(a);

    var a=1;

    以上的语句不会报错,只是提示undefined。实际的运行过程:

    var a;

    console.log(a);

    a=1;表示变量a已声明,但还未赋值。但是变量提升只对var命令声明的变量有效,如果一个变量不是var变量声明的,就不会发生变量提升,例如以下实例:

    console.log(aa);

    aa=1;以上代码将会报错aa is not defined

与普通变量一样,js中的function也可看做变量,也存在变量提升的情况:

    a();

function a(){

    console.log(1);

}

表面上,上面的代码好像在声明之前就调用了函数a。但是实际上,由于变量提升,函数a定义部分被提升到了代码头部,也就是在调用之前已经声明了。但是,如果采用赋值语句定义函数,JavaScript就会报错:

a();

var a=function(){

console.log(1);

}//会报 a is not a function

因为实际运行过程:

var a;

a();

a=function(){

    console.log(1);

}//这时候a是个变量,并非function

你可能感兴趣的:(javascript)