The original intention of this series of articles is to “let each front-end engineer master the high frequency knowledge, for the work of power”. This is the front end of the fifth cut, I hope friends pay attention to the public number “kite”, armed with knowledge of their minds

5.1 introduction

Objects are the most common part of programming. In many cases, properties on the object need to be traversed. So how many ways can we traverse properties on the object? Here are nine ways to do it.

The objects used for the following test methods are as follows:

const parentObj = {
    a: 'aaaaa'.b: Symbol('bbbbb'),
    c: 'ccccc'
};

const Obj = Object.create(parentObj, {
    d: {
        value: 'ddddd'.enumerable: true
    },
    e: {
        value: 'eeeee'.enumerable: false},Symbol('f'] : {value: 'fffff'.enumerable: true}});Copy the code
  1. Object.keys(obj)

Keys returns an array of strings with elements from attributes that can be directly enumerated from the given Object (excluding the Symbol attribute). The order of these attributes is the same as when the object attributes are manually traversed.

console.log('Object.keys()'.Object.keys(Obj)); // Object.keys() [ 'd' ]
Copy the code
  1. Object.values(obj)

Object.values() returns an array of enumerable property values found on the Object. The order of properties is the same as that given by manually looping through the object’s property values.

console.log('Object.values()'.Object.values(Obj)); // Object.values() [ 'ddddd' ]
Copy the code
  1. Object.entries(obj)

Object.entries() returns an array of elements corresponding to key and value pairs of enumerable properties found directly on Object. The order of properties is the same as that given by manually looping through the object’s property values.

console.log('Object.entries()'.Object.entries(Obj)); // Object.entries() [ [ 'd', 'ddddd' ] ]
Copy the code
  1. Object.getOwnPropertyNames(obj)

Object. GetOwnPropertyNames () method returns a specified by the Object of all its attributes of the attribute name (including not enumerated attribute but does not include Symbol value as the name of the attribute) consisting of an array.

console.log('Object.getOwnPropertyNames()'.Object.getOwnPropertyNames(Obj)); // Object.getOwnPropertyNames() [ 'd', 'e' ]
Copy the code
  1. Object.getOwnPropertySymbols(obj)

Object. GetOwnPropertySymbols () method returns a given Object itself all the attributes of the Symbol of the array.

console.log('Object.getOwnPropertySymbols()'.Object.getOwnPropertySymbols(Obj)); // Object.getOwnPropertySymbols() [ Symbol(f) ]
Copy the code
  1. The for… in

Iterate through all the enumerable properties (including those on the stereotype), and then use hasOwnProperty to determine if the object contains a specific (non-inherited) property of its own that has the following characteristics:

Index is a string number that cannot be directly used for geometric operations

(2) The traversal order may not follow the internal order of the actual array

(3) All enumerable attributes of a number group are iterated, including archetypes

(4) for… In is better for convenience objects, don’t use for… In traverses the number group

for(let key in Obj) {
    // for in: d
    // for in: a
    // for in: b
    // for in: c
    console.log('for in:', key);
}
Copy the code
  1. The for… of

You can use the Iterator interface only after it is deployed. Scope of use: Array, Set and Map structures, array-like objects (arguments, DOMNodeList objects…) , Generator object, and string

for(let value of Object.values(Obj)) {
    // for of: ddddd
    console.log('for of:', value);
}
Copy the code
  1. forEach

Using break does not break the loop

Object.values(Obj).forEach(value => {
    // forEach: ddddd
    console.log('forEach:', value);
});
Copy the code
  1. Reflect.ownKeys(obj)

Returns an array containing all the properties of the object itself, whether the property name is Symbol, string, or enumerable.

console.log('Reflect.ownKeys()', Reflect.ownKeys(Obj)); // Reflect.ownKeys() [ 'd', 'e', Symbol(f) ]
Copy the code

5.2 Features summary

type The characteristics of
Object.keys(obj) Returns a directly enumerable property of the object itself (without the Symbol property)
Object.values(obj) Returns the directly enumerable property value of the object itself (without the Symbol property)
Object.entries(obj) Returns an array corresponding to the key-value pairs of the object’s own enumerable properties (excluding the Symbol property)
Object.getOwnPropertyNames(obj) Returns the property names of all the properties of the object itself (excluding the properties with the Symbol value as the name)
Object.getOwnPropertySymbols(obj) Returns an array of all Symbol properties for a given object itself
The for… in All enumerable properties (including those on prototypes)
The for… of You must deploy the Iterator interface, such as arrays, Set and Map structures, array-like objects, Generator objects, and strings
forEach Break Cannot break the loop
Reflect.ownKeys(obj) All properties of the object itself

5.3 Traversal Sequence

The same rules apply for traversal of an object’s properties:

  1. The first step is to iterate through all the attributes with the attribute name numeric, sorting them by number

  2. The next step is to iterate over all properties with the property name string, sorted by generation time

  3. Finally, all properties with the attribute name Symbol value are iterated, sorted by generation time

Verify the traversal rule above with the following code

const Obj = {
    [Symbol(0)]: 'symbol'.1 : '1'.'c': 'c'.'1a1': '11'.22223333: '2'.'d': 'd'
};

console.log(Reflect.ownKeys(Obj)); // [ '1', '22223333', 'c', '1a1', 'd', Symbol(0) ]
Copy the code

1. If you think this article is good, share and like it so that more people can see it

2. Pay attention to the public number of kite, and the number of the Lord together to kill the front hundred.