网络编程
位置:首页>> 网络编程>> JavaScript>> 如何编写高质量的Javascript代码(2)

如何编写高质量的Javascript代码(2)

 来源:rockux 发布时间:2011-03-07 16:04:00 

标签:javascript,代码,经验

全局变量的问题

全局变量的问题在于,他在你的所有代码或者一个页面中都共享。他们在同一个命名空间下面,这通常会造成变量名冲突–两个同名的变量,但是确实不同的用处。

通常在一些页面中需要引入一些其他人的代码,比如:

第三方的JS库

广告伙伴的脚本

第三方的用户行为分析或者统计脚本

不同的组件、按钮等等

加入其中一个第三方组件定义了一个全局变量:result。然后在你的程序中,也定义了一个全局变量result。最后的这个result会覆盖点之前的result,这样第三方的脚本就会停止工作。

所以,为了对其他的脚本友好,在一个页面中使用越少的全局变量越好。在后面会有一些方法来告诉你如何减少全局变量,比如使用命名空间,或者自执行的匿名函数,但是最好的避免全局变量的方法就是使用var关键字来声明变量。

因为javascript的两个特性,创建一个全局变量非常的简单。第一,你可以使用一个甚至没有声明的变量,第二,在javascript中,所有未声明的变量都会成为全局对象的一个属性(就像一个声明了的全局变量一样)。看看这个例子:




function sum(x,y){
     result = x + y;
     return result;
}

在这个代码中,result在没有被声明的情况下就被使用了,这个代码也能很好的工作,但是在调用了这个函数之后,就会多一个名为result的全局变量,这是所有问题的根源了。

解决这个问题的办法就是使用var:




function sum(x,y){
     var result  = x + y;
     return result;
}

两外一个不好的习惯就是在声明变量的时候使用链式的方法来赋值,这时候,a是局部变量,但是b就成为了全局变量。




function foo(){
     var a=b=0;
     ....
}

这是因为,b = 0这个表达式先执行,执行的时候b并没有被声明,所以b就成为了全局变量,然后返回这个表达式的值0,给声明了的变量a,换句话说,就好像你输入的是:




var a = (b=0);

如果你已经声明变量,那么这种链式的赋值没有问题:




function foo(){
     var a,b;
     ...
}

另外一个避免使用全局变量的原因是考虑到程序的可移植性。如果你想让你的代码在不同的环境中都可以工作,那么使用全局变量就很可能会与新的系统中的全局变量冲突(或许在之前的系统中没有问题)。

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com