91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript工具庫之Lodash的示例分析

發布時間:2021-08-11 14:21:26 來源:億速云 閱讀:172 作者:小新 欄目:web開發

小編給大家分享一下JavaScript工具庫之Lodash的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

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。

以上是“JavaScript工具庫之Lodash的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永川市| 汝南县| 阿巴嘎旗| 桐梓县| 宁海县| 兰坪| 祥云县| 南丰县| 甘南县| 宜兰县| 蒲城县| 瑞昌市| 图木舒克市| 洱源县| 凤凰县| 锡林郭勒盟| 玉树县| 武安市| 郎溪县| 宜都市| 孝感市| 成武县| 大丰市| 洛阳市| 嘉定区| 英吉沙县| 河北省| 合作市| 蓬溪县| 崇义县| 象山县| 屏山县| 常山县| 崇礼县| 政和县| 高清| 临颍县| 板桥市| 汤阴县| 邛崃市| 乌鲁木齐市|