提升,隐含全局变量与全局变量

 

提升

javascript允许在函数任意地方声明多个变量,无论在哪里声明,这就是所谓的“提升”。当先使用变量再在函数后面声明变量时可能会导。对javascript而言,只要变量是在同一个范围(同一个函数)里,就视为已经声明,哪怕是在变量声明前就使用。

//反模式
myname="global";//全局变量
function func(){
alert(myname);//"未定义"
var myname="local";
alert(myname);//"局部变量"
}
func();

 

这个例子中,可能以为第一个alert()会提示为“全局变量”,第二个为“局部变量”,这是一个合乎情理的期望,因为在第一个alert中,myname没有声明,因此函数可能“看到“全局变量myname。但事实并不是这样,第一个alert会被指名为“未定义”,因为myname被看做声明为函数的本地变量(尽管是在后面声明)。所有的变量声明都提升到函数的最顶层。因此,为了避免这类混乱,最好在开始就声明要用的所有变量。

前面的代码片段运行结果和以下代码一样。

因为在第一个alert中,myname没有声明,因此函数可能“看到“全局变量myname。但事实并不是这样,第一个alert会被指名为“未定义”,因为myname被看做声明为函数的本地变量(尽管是在后面声明)。所有的变量声明都提升到函数的最顶层。因此,为了避免这类混乱,最好在开始就声明要用的所有变量。

前面的代码片段运行结果和以下代码一样。

myname=global;//全局变量
function func(){
var myname;// 等同于ver myname=undefined;‘
alert(mynam);//"未定义"
myname=local;
alert(myname);//"局部
func()”

 

 

注意:为了完整起见,再谈谈实现级别上的事情,事实上它们更为复杂,代码处理上分为两个阶段,第一,这是一个阶段创建变量,函数声明及形式参数。这是解析和进入上,下文的阶段。第二个阶段是代码运行时执行过程,创建函数表达和不合格的标识符(未定义变量)。但为了实际使用的目的,我们采纳了“提升”的概念,这个概念没有在ECMASript标准中定义,但经常用来表述这种情形。

 

隐含全局变量与全局变量

隐含全局变量与明确定义的全局变量有细微的不同,不同之处在于能否使用delect操作符撤销变量。

使用var创建的全局变量(这类变量在函数外部创建)不能被删除。

不使用var创建的隐含全局变量(尽管它是在函数内部创建)可以删除。

表示隐含全局变量不是真正的变量,而是全局变量的属性。属性可以通过delect操作符删除,但变量不可以。

//定义三个全局变量
var global_var=1;
global_novar=2;//反模式
(function(){
global_fromfunc=3;//反模式
}());
//企图删除
delect global_var;//false
delect global_novar;//true
delect global_fromfunc;//true
//测试删除情况
typeof golobal_var;//"number"类型

typeof global_novar;//"undefined"类型

typeof global_fromfunc;/"undefined"类型

 参考资料:《JavaScript模式》

你可能感兴趣的:(全局变量)