javascript 에서 hasOwnProperty () 방법 사용 안내

2528 단어
개술
hasOwnProperty () 방법 은 특정한 대상 이 지정 한 자신의 속성 을 가지 고 있 는 지 판단 하 는 데 사용 된다.
문법 obj. hasOwnProperty (prop)
매개 변수
•prop
• 검사 할 속성 이름 입 니 다.
묘사 하 다.
Object. prototype 을 계승 한 모든 대상 은 원형 체인 에서 hasOwnProperty 방법 으로 계승 된다. 이 방법 은 한 대상 이 특정한 자신의 속성 을 가지 고 있 는 지, in 연산 자 와 달리 원형 체인 에서 계승 한 속성 을 무시 할 수 있다.
예시
예 1: hasOwnProperty 방법 으로 특정한 대상 이 특정한 자신의 속성 을 가지 고 있 는 지 판단 한다.
다음 예 에서 대상 o 가 자신의 속성 prop 을 포함 하고 있 는 지 확인 하 였 습 니 다.
 
  
o = new Object();o.prop = 'exists';function changeO() {
  o.newprop = o.prop;
  delete o.prop;}o.hasOwnProperty('prop');  
  // true
  changeO();
   o.hasOwnProperty('prop'); 
   // false

예 2: 자신 속성 과 계승 속성의 차이
아래 의 예 는 hasOwnProperty 방법 이 자신의 속성 과 계승 속성 에 대한 차 이 를 보 여 줍 니 다.
 
  
o = new Object();o.prop = 'exists';o.hasOwnProperty('prop');           
 // true
 o.hasOwnProperty('toString');        
 // false
 o.hasOwnProperty('hasOwnProperty');  
 // false

예 3: 한 대상 의 모든 속성 을 옮 겨 다 니 기
다음 예 는 한 대상 의 모든 속성 을 옮 겨 다 닐 때 계승 속성 을 무시 하 는 방법 을 보 여 줍 니 다. 여기 서 for. in 순환 은 매 거 진 속성 만 옮 겨 다 니 는 것 을 주의 하 십시오. 이것 은 보통 우리 가 원 하 는 것 입 니 다. Object. getOwn Property Names () 방법 을 직접 사용 해도 비슷 한 수 요 를 실현 할 수 있 습 니 다.
 
  
var buz = {
    fog: 'stack'};
    for (var name in buz) {
    if (buz.hasOwnProperty(name)) {
        alert("this is fog (" + name + ") for sure. Value: " + buz[name]);
    }
    else {
        alert(name);
         // toString or something else   
         }}

예 4: hasOwnProperty 방법 이 가 려 질 수 있 습 니 다.
대상 이 자신의 hasOwnProperty 방법 을 가지 고 있다 면 원형 체인 의 동명 방법 은 가 려 집 니 다 (shadowed).
 
  
var foo = {
    hasOwnProperty: function() {
        return false;
    },
    bar: 'Here be dragons'};foo.hasOwnProperty('bar');
    // false
    // , hasOwnProperty
    ({}).hasOwnProperty.call(foo, 'bar');
    // true
    Object.prototype.hasOwnProperty.call(foo, 'bar');
    // true

이상 은 본문 에서 말 한 모든 내용 이 니 여러분 들 이 좋아 하 시 기 를 바 랍 니 다.

좋은 웹페이지 즐겨찾기