먼저 null과 정의되지 않음의 차이점에 대해 이야기해 보겠습니다.
선언되었지만 초기화되지 않았거나 선언되지 않은 변수에 대해 typeof를 실행하면 "정의되지 않음"이 반환됩니다.
null은 null 개체 포인터를 나타내며 typeof 연산은 "object"를 반환합니다.
일반적으로 변수의 값은 명시적으로 정의되지 않음으로 설정되지 않지만, 반대로 객체를 저장할 변수의 경우 해당 변수에 null 값을 저장할 수 있도록 명시적으로 허용해야 합니다.
var bj; alert(bj); //"undefined" bj = null; alert(typeof bj); //"object" alert(bj == null); //true bj = {}; alert(bj == null); //false
덩 선배님이 저에게 다음 두 가지 기능을 맡겨주셨어요. 감사합니다.
/* * 检测对象是否是空对象(不包含任何可读属性)。 * 方法既检测对象本身的属性,也检测从原型继承的属性(因此没有使hasOwnProperty)。 */ function isEmpty(obj) { for (var name in obj) { return false; } return true; };
여기서 언급된 빈 개체는 {} 또는 null입니다. 테스트 케이스를 작성했습니다.
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의 차이점:
이것은 매우 중요합니다.
var a = {}; var b = null; a.name = 'realwall'; b.name = 'jim'; //这里会报错,b为空指针对象,不能像普通对象一样直接添加属性。 b = a; b.name = 'jim'; //此时 a 和 b 指向同一个对象。a.name, b.name 均为'jam'