亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JavaScript工具庫之Lodash詳解

2024-05-06 16:52:13
字體:
來源:轉載
供稿:網友

前言

你還在為JavaScript中的數據轉換、匹配、查找等煩惱嗎?一堆看似簡單的foreach,卻冗長無趣,可仍還在不停的repeat it!也許你已經用上了Underscore.js,不錯,你已經進步很大一步了。然而今天我希望你能更進一步,利用lodash替換掉Underscore。

lodash一開始是Underscore.js庫的一個fork,因為和其他(Underscore.js的)貢獻者意見相左。John-David Dalton的最初目標,是提供更多“一致的跨瀏覽器行為……,并改善性能”。之后,該項目在現有成功的基礎之上取得了更大的成果。最近lodash也發布了3.5版,成為了npm包倉庫中依賴最多的庫。它正在擺脫屌絲身份,成為開發者的常規的選擇之一。

現在我們所熟知的很多開源項目都已經使用或者轉到了lodash陣營之上。比如JavaScript轉譯器Babel、博客平臺Ghost,和項目腳手架工具Yeoman。特別Ghost是從Underscore遷移到了lodash,Ghost的創始人John O'Nolan對于此曾評價到:“這是一個非常明智的選擇,它幾乎完全是由我們開源開發社區推動的。我們發現lodash包含更多的功能,更好的性能、恰到好處地使用了semver,并且在Node.js社區(以及其他依賴)中越來越搶眼“。

lodash演練

lodash主要使用了延遲計算,使得lodash其性能遠遠超過Underscore。在lodash中延遲計算意味著在我們的鏈式方法在顯示或隱式的value()調用之前是不會執行的。由于這種執行的延后,因此lodash可以進行shortcut fusion這樣的優化,通過合并鏈式iteratee大大降低迭代的次數。從而大大提供其執行性能。

百說不如一練,下面我們以用戶信息為例:

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延遲計算的現實value,以及JavaScript的函數式風格。在這里首先將users對象包裝成為lodash對象,再map獲取所有用戶的名稱,并最后利用join將用戶名稱以”,“連接在一起。注意這里只是一串方法鏈,如果你沒有顯樣的調用value方法,使其立即執行的化,你將會得到如下的LodashWrapper延遲表達式:

LodashWrapper {__wrapped__: LazyWrapper, __actions__: Array[1], __chain__: true, constructor: function, after: function…}

因為延遲表達式的存在,因此我們可以多次增加方法鏈,但這并不會被執行,所以不會存在性能的問題,最后知道我們需要使用的時候,使用value顯式立即執行即可。

2. 獲取最年輕的用戶

var youngest = _.chain(users).min(function(user){return user.age;}).value();console.log(youngest);

這里利用了lodash提供的min函數可以輕易的解決。

在這里博主還希望用另外一個方式解釋lodash方法鏈的優化,上面的方法可以等價為下面的方式,以age排序的第一個user:

var youngest2 = _.chain(users).sortBy("age").map(function(user){console.log("map", user);return user;}).first().value();console.log(youngest2);

在這里博主多加了一個map作為log輸出,如果你執行這行代碼的時候,你會驚奇的看見這里只會有一個user的輸出,這點可以證明在立即執行的時候lodash為我們的方法鏈做了可靠的優化;如果我們去掉first函數你則會看見有3個user對象的輸出。

3. 獲取最年長的用戶

var oldest = _.chain(users).max(function(user){return user.age;}).value();console.log(oldest );

這里則使用lodash的max函數。

4. 用戶數組到用戶Map的轉換

在開發中我們經常會有把一堆素組形式的數據轉換為Object形式的數組,便于根據屬性key值查找,下面將以user對象來演示:

var userObj = _.chain(users).map(function(user){return [user.user, user.age];}).zipObject().value();console.log(userObj);

利用lodash首先將user數組map為[key, value]的數組集合,最后利用zipObject將結果轉換為Object對象,zipObject會利用結果集的第一項作為key,第二項作為value生產Object。

結尾

我們在這里展示知識lodash中很小一部分的API,正如隨筆開始所說:lodash是為了提供更多“一致的跨瀏覽器行為……,并改善性能”API。所有的lodash API你可以在這里https://lodash.com/docs#matches查找。

本文的所演示的demo,你也可以在jsbin http://jsbin.com/xocixubaru/1/edit?html,js,output演示。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品国产视频| 国产大片精品免费永久看nba| 久久精品99久久久久久久久| 久久精品国产久精国产思思| 精品亚洲一区二区三区在线观看| 欧美综合国产精品久久丁香| 中文字幕亚洲综合| 精品二区三区线观看| 久久精品视频在线播放| 久久视频在线播放| 久久久久久亚洲精品中文字幕| 在线亚洲男人天堂| 日韩欧美一区二区三区久久| 国产亚洲欧美aaaa| 国产精品福利小视频| 中文字幕亚洲色图| 欧美激情一级二级| 国产成人极品视频| 亚洲欧美日本伦理| 一区二区亚洲精品国产| 97视频在线观看免费高清完整版在线观看| 欧美乱大交xxxxx| 欧美性猛交99久久久久99按摩| 久久成人18免费网站| 91国语精品自产拍在线观看性色| 国产免费久久av| 久久躁日日躁aaaaxxxx| 97在线免费观看| 亚洲天堂开心观看| 欧美一区三区三区高中清蜜桃| 久久五月情影视| 日韩精品在线免费| 国产+成+人+亚洲欧洲| 亚洲亚裔videos黑人hd| 亚洲精品国产综合区久久久久久久| 日韩中文综合网| 97视频免费观看| 全球成人中文在线| 欧美激情乱人伦| 福利一区视频在线观看| 欧美黄色片免费观看| 91av视频在线免费观看| 亚洲国产精品yw在线观看| 欧美激情手机在线视频| 国模精品视频一区二区三区| 日韩国产高清视频在线| 欧美日韩亚洲高清| 精品爽片免费看久久| 久久精品国产成人精品| 日韩欧美一区二区三区久久| 美女精品久久久| 久久人人97超碰精品888| 亚洲精品丝袜日韩| 668精品在线视频| 欧美特级www| 不卡伊人av在线播放| 欧美亚洲一区在线| 精品亚洲国产成av人片传媒| 欧美高清第一页| 国外色69视频在线观看| 国产又爽又黄的激情精品视频| 在线日韩精品视频| 日韩久久免费视频| 国产精品黄视频| 97视频在线观看免费| 久久亚洲精品视频| 色av吧综合网| 国产97在线观看| 福利视频第一区| 久久99视频精品| 九九热这里只有精品免费看| 精品国产精品自拍| 伊人久久综合97精品| 亚洲三级黄色在线观看| 91久久在线观看| 国产亚洲精品久久久优势| 亚洲视频欧美视频| 中文字幕免费精品一区| 欧美电影免费观看高清| 欧美成人精品不卡视频在线观看| 欧美色图在线视频| 国产精品1区2区在线观看| 亚洲人成网站777色婷婷| 国产女人精品视频| 日韩激情av在线免费观看| 色综合久久久久久中文网| 国产日韩欧美电影在线观看| 久久久国产精品免费| 国产精品视频成人| 欧美一级高清免费播放| 国产成人aa精品一区在线播放| 亚洲精品美女久久| 久久久精品国产网站| 91美女片黄在线观| 久久久久久网址| 久久久精品电影| 亚洲精品一区二区在线| 欧美日韩亚洲一区二区三区| 国产精自产拍久久久久久| 久久精品视频在线| 琪琪亚洲精品午夜在线| 亚洲激情视频网| 亚洲一区二区三区成人在线视频精品| 午夜免费在线观看精品视频| 久久久久亚洲精品成人网小说| 久久久亚洲成人| 欧美日韩国产麻豆| 大量国产精品视频| 久久久久久久久久久免费精品| 91国产一区在线| 精品国产一区二区三区在线观看| 精品亚洲夜色av98在线观看| 欧美在线视频在线播放完整版免费观看| 欧美不卡视频一区发布| 国产精品爽爽爽| 欧美午夜久久久| 欧美最猛性xxxxx(亚洲精品)| 国产98色在线| 一本色道久久综合狠狠躁篇怎么玩| 欧美成人激情视频免费观看| 国产精品久久久久影院日本| 午夜精品理论片| 亚洲国产91精品在线观看| 国产成人精品久久二区二区| 国产精品视频免费观看www| 亚洲女人天堂av| 欧美日韩一区二区免费在线观看| 91中文精品字幕在线视频| 这里只有精品视频在线| 亚洲精品天天看| 欧美极品欧美精品欧美视频| 91在线免费观看网站| 538国产精品一区二区免费视频| 91精品久久久久久久久久| 国产精品va在线播放| 国产精品入口夜色视频大尺度| 久久国产色av| 日本aⅴ大伊香蕉精品视频| 国产精品99久久久久久久久| 欧美电影免费观看电视剧大全| 国产一区深夜福利| 精品视频www| 欧美—级a级欧美特级ar全黄| 精品无人国产偷自产在线| 久久久亚洲福利精品午夜| 亚洲人成网7777777国产| 欧美黑人极品猛少妇色xxxxx| 亚洲性线免费观看视频成熟| 欧美成人性生活| 日韩在线免费观看视频| 狠狠躁夜夜躁人人躁婷婷91| 庆余年2免费日韩剧观看大牛| 国产精品jvid在线观看蜜臀| 日韩高清av在线| 久久福利视频网| 亚洲专区国产精品| 欧美视频在线免费看| 91理论片午午论夜理片久久| 欧美性做爰毛片| 精品国产成人av| 久久手机免费视频| 88国产精品欧美一区二区三区| 国产91精品在线播放| 国产日产久久高清欧美一区|