建议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来测试,使用了会强制类型转换的==运算符,而不是更可靠的===运算符。正确的用法如下: - value = myObject[name];
- if(!value) {
- }
undefined和NaN并不是常见,它们是全局变量,还可以改变它们的值,虽然在程序设计中不应该采取这种做法,但可以改变它们的值。