JavaScript 개체가 null인지 또는 속성이 비어 있는지 확인하는 간단한 방법

WBOY
풀어 주다: 2016-05-16 16:35:15
원래의
1480명이 탐색했습니다.

먼저 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'
로그인 후 복사

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿