> 웹 프론트엔드 > JS 튜토리얼 > `for...in`을 사용하여 JavaScript에서 객체 속성을 안전하게 반복하려면 어떻게 해야 합니까?

`for...in`을 사용하여 JavaScript에서 객체 속성을 안전하게 반복하려면 어떻게 해야 합니까?

Linda Hamilton
풀어 주다: 2024-12-29 20:37:18
원래의
231명이 탐색했습니다.

How Can I Safely Iterate Over Object Properties in JavaScript Using `for...in`?

for...in을 사용하여 객체 속성 반복

for...in 루프를 사용하여 객체 속성을 반복할 때 루프 변수 propt는 액세스되는 속성의 키를 나타냅니다. 그러나 이는 객체에 대해 내장된 메서드나 속성이 아닙니다.

for...in 루프는 객체 자체의 속성과 해당 프로토타입에서 상속된 속성을 모두 검색합니다. 상속된 속성이 반복에 포함되지 않을 수 있으므로 문제가 될 수 있습니다.

정확한 반복을 위해 hasOwnProperty 사용

이 문제를 해결하려면 다음을 추가할 수 있습니다. for...in 루프 내에서 hasOwnProperty 검사:

for (var prop in obj) {
    if (Object.prototype.hasOwnProperty.call(obj, prop)) {
        // Do stuff
    }
}
로그인 후 복사

hasOwnProperty 메소드는 속성이 프로토타입에서 상속되지 않고 객체에 직접 정의되었는지 확인합니다. 이 검사를 사용하면 반복에서 상속된 속성을 제외할 수 있습니다.

hasOwnProperty와 객체를 통한 호출

또는 객체 자체를 통해 hasOwnProperty를 호출할 수 있습니다.

if (obj.hasOwnProperty(prop)) {
    // Do stuff
}
로그인 후 복사

그러나 객체에 다음과 같이 hasOwnProperty와 동일한 이름을 가진 관련 없는 필드:

var obj = { foo: 42, hasOwnProperty: 'lol' };
obj.hasOwnProperty('foo'); // TypeError
로그인 후 복사

이 문제를 방지하려면 대신 Object.prototype을 통해 hasOwnProperty를 호출하는 것이 더 안전합니다.

Object.prototype.hasOwnProperty.call(obj, 'foo'); // True
로그인 후 복사

위 내용은 `for...in`을 사용하여 JavaScript에서 객체 속성을 안전하게 반복하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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