对已声明但未初始化的和未声明的变量执行typeof,都返回undefined,null表示一个空对象指针,typeof操作会返回object
首先说下null与undefined区别:
对已声明但未初始化的和未声明的变量执行typeof,都返回"undefined"。
null表示一个空对象指针,typeof操作会返回"object"。
一般不显式的把变量的值设置为undefined,但null相反,对于将要保存对象的变量,应明确的让该变量保存null值。
1
2
3
4
5
6
7
|
var bj;
alert(bj); //"undefined"
bj = null ;
alert( typeof bj); //"object"
alert(bj == null ); //true
bj = {}; alert(bj == null ); //false
|
1
2
3
4
5
6
7
8
9
10
11
12
|
/* * 检测对象是否是空对象(不包含任何可读属性)。 * 方法既检测对象本身的属性,也检测从原型继承的属性(因此没有使hasOwnProperty)。 */ function isEmpty(obj)
{ for ( var name in obj)
{ return false ;
} return true ;
}; |
这里所说的空对象,到底是 {} 还是 null . 我写了一个测试用例。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
var a = {};
a.name = 'realwall' ;
console.log(isEmpty(a)); //false
console.log(isEmpty({})); //true
console.log(isEmpty( null )); //true
//注意参数为null时无语法错误哦,即虽然不能对null空指针对象添加属性,但可以使用for in 语句 ? /* * 检测对象是否是空对象(不包含任何可读属性)。 * 方法只既检测对象本身的属性,不检测从原型继承的属性。 */ function isOwnEmpty(obj)
{ for ( var name in obj)
{ if (obj.hasOwnProperty(name))
{ return false ;
} } return true ;
}; |
{}与null的区别:
这个东西很重要。
1
2
3
4
5
6
7
|
var a = {};
var b = null ;
a.name = 'realwall' ;
b.name = 'jim' ; //这里会报错,b为空指针对象,不能像普通对象一样直接添加属性。
b = a; b.name = 'jim' ; //此时 a 和 b 指向同一个对象。a.name, b.name 均为'jam'
|