天天看点

JS编程建议——6:正确处理JavaScript特殊值(2)

建议6:正确处理JavaScript特殊值(2)

与null不同,undefined不是JavaScript的保留字,在ECMAScript v3标准中才定义undefined为全局变量,初始值为undefined。因此,在使用undefined值时就存在一个兼容问题(早期浏览器可能不支持undefined)。除了直接赋值和使用typeof运算符外,其他任何运算符对undefined的操作都会引发异常。不过,可以声明undefined变量,然后查看它的值,如果它的值为undefined,则说明浏览器支持undefined值。例如:

var undefined;

alert(undefined);

如果浏览器不支持undefined关键字,可以自定义undefined变量,并将其赋值为undefined。例如:

var undefined = void null;

声明变量为undefined,将其初始化为表达式void null的值,由于运算符void在执行其后的表达式时会忽略表达式的结果值,而总是返回值undefined,因此利用这种方法可以定义一个变量为undefined,并将其赋值为undefined。既然是将变量undefined赋值为undefined,还可以使用如下方式:

var undefined = void 1;

或者使用没有返回值的函数:

var undefined = function(){}();

alert(undefined); //"undefined"

可以使用typeof运算符来检测某个变量的值是否为undefined:

var a;

if(typeof a == "undefined"){

}

3.使用假值

JavaScript的类型系统是非常混乱的,类型特性不明显,而且交叉错乱。JavaScript语法系统拥有一大组假值,如以下代码所示。这些值的布尔值都是false。

0 //Number

NaN //Number

'' //String

false //Boolean

null //Object

undefined //Undefined

这些值全部都等同于false,但它们是不可互换的。例如,下面用法是错误的。

value = myObject[name];

if(value == null) {

这是在用一种错误的方式去确定一个对象是否缺少一个成员属性。undefined是缺失的成员属性值,而上面代码片段用null来测试,使用了会强制类型转换的==运算符,而不是更可靠的===运算符。正确的用法如下:

if(!value) {

undefined和NaN并不是常见,它们是全局变量,还可以改变它们的值,虽然在程序设计中不应该采取这种做法,但可以改变它们的值。

继续阅读