[javascript] Object.getOwnPropertyNames 대 Object.keys

자바 스크립트 Object.getOwnPropertyNamesObject.keys자바 스크립트 의 차이점은 무엇입니까 ? 또한 일부 예가 이해 될 것이다.



답변

약간의 차이가 있습니다. Object.getOwnPropertyNames(a)객체의 모든 속성을 반환 합니다 a. 열거 가능한 모든 자체 속성을 Object.keys(a)반환 합니다 . 즉, 객체 속성을 만들지 않고 객체 속성을 정의하면 enumerable: false이 두 가지 방법으로 동일한 결과를 얻을 수 있습니다.

테스트하기 쉽습니다.

var a = {};
Object.defineProperties(a, {
    one: {enumerable: true, value: 'one'},
    two: {enumerable: false, value: 'two'},
});
Object.keys(a); // ["one"]
Object.getOwnPropertyNames(a); // ["one", "two"]

속성 속성 설명자를 제공하지 않고 속성을 정의하는 경우 (사용하지 않음을 의미 Object.defineProperties) 예를 들면 다음과 같습니다.

a.test = 21;

그런 속성은 자동으로 열거 가능하고 두 방법 모두 동일한 배열을 생성합니다.


답변

또 다른 차이점은 배열 Object.getOwnPropertyNames메서드가 추가 속성 인을 반환한다는 것입니다 length.

var x = ["a", "b", "c", "d"];
Object.keys(x);  //[ '0', '1', '2', '3' ]
Object.getOwnPropertyNames(x);  //[ '0', '1', '2', '3', 'length' ]


답변

객체 생성시 리터럴 표기법 vs 생성자 여기에 나를 얻는 것이 있습니다.

const cat1 = {
    eat() {},
    sleep() {},
    talk() {}
};

// here the methods will be part of the Cat Prototype
class Cat {
    eat() {}
    sleep() {}
    talk() {}
}

const cat2 = new Cat()

Object.keys(cat1) // ["eat", "sleep", "talk"]
Object.keys(Object.getPrototypeOf(cat2)) // []

Object.getOwnPropertyNames(cat1) // ["eat", "sleep", "talk"]
Object.getOwnPropertyNames(Object.getPrototypeOf(cat2)) // ["eat", "sleep", "talk"]

cat1 // {eat: function, sleep: function, talk: function}
cat2 // Cat {}

// a partial of a function that is used to do some magic redeclaration of props
function foo(Obj) {
    var propNames = Object.keys(Obj);

    // I was missing this if
    // if (propNames.length === 0) {
    //     propNames = Object.getOwnPropertyNames(Obj);
    // }

    for (var prop in propNames) {
        var propName = propNames[prop];

        APIObject[propName] = "reasign/redefine or sth";
    }
}

따라서 필자의 경우 foocat2 유형의 객체를 제공하면 함수가 작동하지 않았습니다.

객체를 만드는 다른 방법이 있으므로 거기에 다른 꼬임이있을 수 있습니다.


답변

이미 설명했듯이 .keys열거 가능한 속성을 반환하지 않습니다.

예제와 관련하여 함정 사례 중 하나는 Error객체입니다. 일부 속성은 열거 할 수 있습니다.
그래서 잠시 console.log(Object.keys(new Error('some msg')))생산량 [],
console.log(Object.getOwnPropertyNames(new Error('some msg')))수율["stack", "message"]

console.log(Object.keys(new Error('some msg')));
console.log(Object.getOwnPropertyNames(new Error('some msg')));


답변

또 다른 차이점은 (적어도 nodejs와 함께) “getOwnPropertyNames”함수는 키 순서를 보장하지 않으므로 일반적으로 “키”함수를 사용합니다.

    Object.keys(o).forEach(function(k) {
      if (!o.propertyIsEnumerable(k)) return;
      // do something...
    });


답변