欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript工具庫之Lodash詳解

 更新時間:2019年06月15日 11:58:46   作者:Unknw  
這篇文章主要介紹了JavaScript工具庫之Lodash詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,,需要的朋友可以參考下

前言

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

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

現(xiàn)在我們所熟知的很多開源項目都已經使用或者轉到了lodash陣營之上。比如JavaScript轉譯器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()調用之前是不會執(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ù)式風格。在這里首先將users對象包裝成為lodash對象,再map獲取所有用戶的名稱,并最后利用join將用戶名稱以”,“連接在一起。注意這里只是一串方法鏈,如果你沒有顯樣的調用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);

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

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

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

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

3. 獲取最年長的用戶

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

這里則使用lodash的max函數(shù)。

4. 用戶數(shù)組到用戶Map的轉換

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

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

利用lodash首先將user數(shù)組map為[key, value]的數(shù)組集合,最后利用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演示。

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

相關文章

  • 在JavaScript中如何解決用execCommand(

    在JavaScript中如何解決用execCommand(

    這篇文章主要給大家介紹在JavaScript中如何解決用execCommand("SaveAS")保存頁面兼容性問題,設計到execCommand兼容性問題,感興趣的朋友可以參考下本篇文章
    2015-10-10
  • 前端圖片懶加載的原理與3種實現(xiàn)方式舉例

    前端圖片懶加載的原理與3種實現(xiàn)方式舉例

    圖片懶加載又稱圖片延時加載、惰性加載,即在用戶需要使用圖片的時候加載,這樣可以減少請求,節(jié)省帶寬,提高頁面加載速度,相對的,也能減少服務器壓力,下面這篇文章主要給大家介紹了關于前端圖片懶加載的原理與3種實現(xiàn)方式的相關資料,需要的朋友可以參考下
    2023-03-03
  • 通過JS 獲取Mouse Position(鼠標坐標)的代碼

    通過JS 獲取Mouse Position(鼠標坐標)的代碼

    最近我發(fā)現(xiàn)在webpage中獲取空間的絕對坐標時,如果有滾動條就會有錯,后來用無名發(fā)現(xiàn)的方法得以解決。
    2009-09-09
  • Javascript操縱Cookie實現(xiàn)購物車程序

    Javascript操縱Cookie實現(xiàn)購物車程序

    Javascript操縱Cookie實現(xiàn)購物車程序...
    2006-11-11
  • JavaScript函數(shù)調用經典實例代碼

    JavaScript函數(shù)調用經典實例代碼

    JavaScript提供了4種函數(shù)調用,一般形式的函數(shù)調用、作為對象的方法調用、使用 call 和 apply 動態(tài)調用、使用 new 間接調用,下面這篇文章主要給大家介紹了關于JavaScript函數(shù)調用的相關資料,需要的朋友可以參考下
    2021-12-12
  • Sample script that displays all of the users in a given SQL Server DB

    Sample script that displays all of the users in a given SQL

    Sample script that displays all of the users in a given SQL Server DB...
    2007-06-06
  • js封裝成插件的步驟方法

    js封裝成插件的步驟方法

    本篇文章主要介紹了js封裝成插件的步驟方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • js中的面向對象入門

    js中的面向對象入門

    本文主要介紹了js中的面向對象的相關知識,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • JS電梯導航的實現(xiàn)示例

    JS電梯導航的實現(xiàn)示例

    本文主要介紹了JS電梯導航的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • Python要求每行輸出5個的示例代碼

    Python要求每行輸出5個的示例代碼

    本文從列表、字符串和數(shù)字三個方面詳細闡述了Python中要求每行輸出5個的相關內容,并給出了相應的代碼示例,在實際開發(fā)中,我們可以根據具體的需求靈活運用這些方法,以提高程序的輸出效率和可讀性,需要的朋友可以參考下
    2020-05-05

最新評論