Object.keys()
一呛哟、官方解釋
Object.keys() 方法會返回一個由一個給定對象的自身可枚舉屬性組成的數(shù)組,數(shù)組中屬性名的排列順序和使用 for...in 循環(huán)遍歷該對象時返回的順序一致 匿沛。如果對象的鍵-值都不可枚舉扫责,那么將返回由鍵組成的數(shù)組。
二逃呼、語法
Object.keys(obj)
參數(shù):要返回其枚舉自身屬性的對象
返回值:一個表示給定對象的所有可枚舉屬性的字符串?dāng)?shù)組
三鳖孤、處理對象,返回可枚舉的屬性數(shù)組
let person={
name:'一只流浪的kk',
age:20,
eat:function(){}
}
console.log(Object.keys(person));// ['name','age','eat']
四抡笼、處理數(shù)組苏揣,返回索引值數(shù)組
let arr=[1,2,3,4,5];
console.log(Object.keys(arr));//['0','1','2','3','4','5']
五、處理字符串推姻,返回索引值數(shù)組
let str='hello';
console.log(Object.keys(str));//['0','1','2','3','4']
六腿准、實(shí)用技巧
let person={
name:'一只流浪的kk',
age:18,
eat:function(){
}
}
Object.keys(person).map((key)=>{
person[key];//獲得屬性對應(yīng)的值,可以進(jìn)行其它處理
})
Object.values()
一拾碌、返回一個數(shù)組,成員是參數(shù)對象自身的(不含繼承的)所有可遍歷屬性的鍵值
let obj = {
foo : "bar",
baz : 20
};
console.log(Object.values(obj)); // ["bar", 20]
二街望、返回數(shù)組的成員順序校翔,與屬性的遍歷部分介紹的排列規(guī)則一致
const obj = {100 : "a", 2 : "b", 7 : "c"};
console.log(Object.values(obj)); //["b", "c", "a"]
三、Object.values()只會遍歷對象自身的可遍歷屬性
const obj = Object.create({},{p : {value : 10}});
console.log(Object.values(obj));
console.log(Object.getOwnPropertyDescriptors(obj)); // []
Object.create方法的第二個參數(shù)添加的對象屬性(屬性p)灾前,如果不顯式聲明防症,默認(rèn)是不可遍歷的,因?yàn)閜的屬性描述對象的enumerable默認(rèn)是false哎甲,Object.values不會返回這個屬性蔫敲。
因此只要把enumerable改成true,Object.values就會返回屬性p的值炭玫。
const obj = Object.create({},{p:{
value : 10,
enumerable : true,
configurable : true,
writable : true,
}})
console.log(Object.values(obj)); //[10]
四奈嘿、Object.values會過濾屬性名為 Symbol 值的屬性
//如果Object.values方法的參數(shù)是一個字符串,會返回各個字符組成的一個數(shù)組吞加。
Object.values({ [Symbol()]: 123, foo: 'abc' });
console.log(Object.values('foo')); //["f", "o", "o"]
五裙犹、如果參數(shù)不是對象尽狠,Object.values會先將其轉(zhuǎn)為對象
console.log(Object.values(42)); // []
console.log(Object.values(true)); // []
console.log(Object.values(undefined)); //error
console.log(Object.values(null)); //error
Object.entries()
一、Object.entries方法返回一個數(shù)組叶圃,成員是參數(shù)對象自身的(不含繼承的)所有可遍歷(enumerable)屬性的鍵值對數(shù)組
var obj = { foo: 'bar', baz: 42 };
console.log(Object.entries(obj));
二袄膏、如果原對象的屬性名是一個 Symbol 值,該屬性會被省略
console.log(Object.entries({ [Symbol()]: 123, foo: 'abc' })); // [ [ 'foo', 'abc' ] ]
三掺冠、遍歷對象的屬性
let obj = {
one : 1,
two : 2,
}
for(let [k , v] of Object.entries(obj)){
console.log(`${JSON.stringify(k)} : ${JSON.stringify(v)}`);
}
四沉馆、將對象轉(zhuǎn)為真正的Map結(jié)構(gòu)
const obj = {foo : "bar", baz : 10};
const map = new Map(Object.entries(obj));
console.log(map);
五、實(shí)現(xiàn)Object.entries方法
const entries = (obj) => {
let result = [];
const objType = typeof(obj);
if(obj === undefined || obj === null){
throw new TypeError();
}
if(objType === "number" || objType === "boolean"){
return [];
}
for(let k of Object.keys(obj)){
result.push([k,obj[k]]);
}
return result
}