前言
你還在為JavaScript中的數(shù)據(jù)轉(zhuǎn)換、匹配、查找等煩惱嗎?一堆看似簡單的foreach,卻冗長無趣,可仍還在不停的repeat it!也許你已經(jīng)用上了Underscore.js,不錯,你已經(jīng)進步很大一步了。然而今天我希望你能更進一步,利用lodash替換掉Underscore。
lodash一開始是Underscore.js庫的一個fork,因為和其他(Underscore.js的)貢獻者意見相左。John-David Dalton的最初目標,是提供更多“一致的跨瀏覽器行為……,并改善性能”。之后,該項目在現(xiàn)有成功的基礎(chǔ)之上取得了更大的成果。最近lodash也發(fā)布了3.5版,成為了npm包倉庫中依賴最多的庫。它正在擺脫屌絲身份,成為開發(fā)者的常規(guī)的選擇之一。
現(xiàn)在我們所熟知的很多開源項目都已經(jīng)使用或者轉(zhuǎn)到了lodash陣營之上。比如JavaScript轉(zhuǎn)譯器Babel、博客平臺Ghost,和項目腳手架工具Yeoman。特別Ghost是從Underscore遷移到了lodash,Ghost的創(chuàng)始人John O'Nolan對于此曾評價到:“這是一個非常明智的選擇,它幾乎完全是由我們開源開發(fā)社區(qū)推動的。我們發(fā)現(xiàn)lodash包含更多的功能,更好的性能、恰到好處地使用了semver,并且在Node.js社區(qū)(以及其他依賴)中越來越搶眼“。
lodash演練
lodash主要使用了延遲計算,使得lodash其性能遠遠超過Underscore。在lodash中延遲計算意味著在我們的鏈式方法在顯示或隱式的value()調(diào)用之前是不會執(zhí)行的。由于這種執(zhí)行的延后,因此lodash可以進行shortcut fusion這樣的優(yōu)化,通過合并鏈式iteratee大大降低迭代的次數(shù)。從而大大提供其執(zhí)行性能。
百說不如一練,下面我們以用戶信息為例:
var users = [{ 'user': 'barney', 'age': 36 },{ 'user': 'fred', 'age': 40 },{ 'user': 'pebbles', 'age': 18 }];1.獲取所有用戶名字,并以”,“分割
var names = _.chain(users).map(function(user){return user.user;}).join(" , ").value();console.log(names);個人比較喜歡lodash延遲計算的現(xiàn)實value,以及JavaScript的函數(shù)式風(fēng)格。在這里首先將users對象包裝成為lodash對象,再map獲取所有用戶的名稱,并最后利用join將用戶名稱以”,“連接在一起。注意這里只是一串方法鏈,如果你沒有顯樣的調(diào)用value方法,使其立即執(zhí)行的化,你將會得到如下的LodashWrapper延遲表達式:
LodashWrapper {__wrapped__: LazyWrapper, __actions__: Array[1], __chain__: true, constructor: function, after: function…}
因為延遲表達式的存在,因此我們可以多次增加方法鏈,但這并不會被執(zhí)行,所以不會存在性能的問題,最后知道我們需要使用的時候,使用value顯式立即執(zhí)行即可。
2. 獲取最年輕的用戶
var youngest = _.chain(users).min(function(user){return user.age;}).value();console.log(youngest);
新聞熱點
疑難解答
圖片精選