라이브러리

[JAVASCRIPT] Object.hasOwn(obj, prop) - 객체가 특정 속성을 직접 가지고 있는지 확인




Object.hasOwn() 메서드


`Object.hasOwn()` 메서드는 객체의 특정 속성 존재 여부를 확인하는 메서드입니다. 이 메서드는 ES11(ECMAScript 2022)에서 추가된 메서드이며, 이전 버전의 JavaScript에서는 `in` 연산자나 `hasOwnProperty()` 메서드를 사용했습니다.

Syntax


#hostingforum.kr
javascript

Object.hasOwn(obj, prop)



* `obj`: 확인할 객체
* `prop`: 확인할 속성 이름

반환 값


`Object.hasOwn()` 메서드는 속성이 존재하면 `true`, 존재하지 않으면 `false`를 반환합니다.

예제


#hostingforum.kr
javascript

// 객체 생성

const person = {

    name: 'John',

    age: 30,

    occupation: 'Developer'

};



// 속성이 존재하는지 확인

console.log(Object.hasOwn(person, 'name')); // true

console.log(Object.hasOwn(person, 'age'));  // true

console.log(Object.hasOwn(person, 'occupation')); // true

console.log(Object.hasOwn(person, 'address')); // false



// 속성이 존재하지 않는 경우

console.log(Object.hasOwn({}, 'name')); // false



사용 이유


`Object.hasOwn()` 메서드는 `in` 연산자나 `hasOwnProperty()` 메서드보다 더 안전하고 효율적으로 속성을 확인할 수 있습니다. 특히, `in` 연산자는 상위 객체의 속성을 확인할 수도 있으므로, `Object.hasOwn()` 메서드를 사용하여 속성이 객체 내부에 존재하는지 확인할 수 있습니다.

참고


* `Object.hasOwn()` 메서드는 `in` 연산자와 다르게 상위 객체의 속성을 확인하지 않습니다.
* `Object.hasOwn()` 메서드는 `hasOwnProperty()` 메서드와 다르게 null 또는 undefined 값을 반환하지 않습니다.

결론


`Object.hasOwn()` 메서드는 객체의 속성을 안전하고 효율적으로 확인할 수 있는 메서드입니다. 속성이 존재하는지 확인할 때 사용하면 유용합니다.
  • profile_image
    나우호스팅 @pcs8404 

    호스팅포럼 화이팅!

    댓글목록

    등록된 댓글이 없습니다.

  • 전체 10,077건 / 11 페이지

검색

게시물 검색