Javascript ES6標準實行後,Lodash或者Ramada中的一些功能我們就不需要了,可以使用ES6的語法來實現
獲取Object中指定鍵值
我們現在可以使用解包的方法快速獲取物件中指定鍵值的值
const obj = {
a:1,
b:2,
c:3,
d:4
};
// 獲取obj中a與b的值
const {a,b} = obj;
// 也可以給他們取別名
const {a:A, b:B} = obj;
複製程式碼
這個小技巧非常的方便,也是最基礎的使用方法
排除Object中不需要的鍵值
既然我們可以獲取到想要的物件鍵值,那麼也可以排除掉不想要的鍵值,使用方法就要用到ES6的rest新特性
const obj = {
a:1,
b:2,
c:3,
d:4
}
// 我們想要獲取除了a之外的所有屬性
const {a, ...other} = obj
複製程式碼
我們只要指定那些排除掉的屬性,剩下的就是需要的屬性,這樣可以非常快速的排除不需要的屬性
物件快速求和
有時候我們需要對一組物件陣列中的某一個屬性求總和,以前我們可以使用forEach
或者for
這樣的迴圈遍歷的方法來計算,現在我們可以使用reduce
方法來快速實現
const objs = [
{name:'lilei', score: 98},
{name:'hanmeimei', score: 95},
{name:'polo', score: 85},
...
]
const scoreTotal = objs.reduce( (total, obj) => {
return obj.score + total;
}, 0 /*第二個引數是total的初始值*/)
複製程式碼
使用reduce
就能快速的實現對某一個屬性的總和計算
map也能非同步遍歷
是不是覺得只有for
能夠進行非同步操作不方便,其實map
也能進行非同步操作,不過需要結合Promise
的新方法一起使用
const arr = [1,2,3,4,...]
const queue = arr.map(async item => {
return item + 1;
})
Promise.all(queue).then(newArr => console.log(newArr))
複製程式碼
這樣一來我們在map
中也能使用非同步操作了