2018年你需要知道的13個JavaScript工具庫

v2-307971e2f3800cf8ee6fde8a2e9ea1cc_1200x500.jpg

譯者按: 你可能已經(jīng)用到Underscore或者Lodash。本文列舉了13個常用的JavaScript工具庫來提高開發(fā)效率。

為了保證可讀性,本文采用意譯而非直譯。另外,本文版權(quán)歸原作者所有,翻譯僅用于學(xué)習(xí)。

JavaScript依然是2018年最受歡迎、最流行的編程語言,所以它的生態(tài)系統(tǒng)也十分完善。

image

JavaScript小小的標(biāo)準(zhǔn)庫已經(jīng)不足以應(yīng)付各種開發(fā)需求。在Github上,有許多流行的JavaScript工具庫。在這里,我整理了一個列表推薦給大家:

1. Underscore & Lodash

也許大多數(shù)童鞋都已經(jīng)知道它們。Underscore提供了日常使用的基礎(chǔ)函數(shù)。Lodash, 作為NPM最多下載量和被依賴最多的包,旨在為數(shù)組,字符串,對象和參數(shù)對象提供更一致的跨環(huán)境迭代支持。它已經(jīng)是Underscore的超集。Underscore和Lodash由同一組核心開發(fā)者維護(hù)。你日常開發(fā)中絕對少不了要用到它。

2. Ramda

擁有超過12K的stars,Ramda庫可以用來在JavaScript中函數(shù)式編程,專門為函數(shù)式編程風(fēng)格而設(shè)計(jì),更容易創(chuàng)建函數(shù)式pipeline、且從不改變用戶已有數(shù)據(jù)。

摘自官方:

Ramda 主要特性如下:

  • Ramda 強(qiáng)調(diào)更加純粹的函數(shù)式風(fēng)格。數(shù)據(jù)不變性和函數(shù)無副作用是其核心設(shè)計(jì)理念。這可以幫助你使用簡潔、優(yōu)雅的代碼來完成工作。
  • Ramda 函數(shù)本身都是自動柯里化的。這可以讓你在只提供部分參數(shù)的情況下,輕松地在已有函數(shù)的基礎(chǔ)上創(chuàng)建新函數(shù)。
  • Ramda 函數(shù)參數(shù)的排列順序更便于柯里化。通常最后提供要操作的數(shù)據(jù)。

最后兩點(diǎn)一起,使得將多個函數(shù)組合為簡單的函數(shù)序列變得非常容易,每個函數(shù)對數(shù)據(jù)進(jìn)行變換,并將結(jié)果傳遞給下一個函數(shù)。Ramda的設(shè)計(jì)能很好地支持這種風(fēng)格的編程。

你也可以看看:immutable.js

3. MathJS

擁有超過6K的stars,Math.js是一個Node.js和JavaScript上的math擴(kuò)展庫,并且和內(nèi)置的Math庫兼容。該庫中包含一個靈活的表達(dá)式分析器,并且有非常多的內(nèi)置函數(shù)可以使用。你甚至可以自行做擴(kuò)展。

4. Moment & date-fns

擁有超過40K的stars,moment.js是一個JavaScript的時間處理庫,可以用來分析、驗(yàn)證、處理和格式化時間。Moment被設(shè)計(jì)可以用于瀏覽器和Node.js環(huán)境下。對于V2.10.0,代碼完全用ECMAScript 6實(shí)現(xiàn)。

Date-fns也是一個非常流行(超過11K的stars)的時間處理庫,提供超過130多個函數(shù),很多人把它當(dāng)做moment.js(查看對比)的替代品。Date-fns完全用純函數(shù)實(shí)現(xiàn),保證不可修改性。它可以很好的和webpack,Browserify、或Rollup配合使用,并支持tree-shaking。

5. Sugar

擁有超過3.5K個stars,Sugar是一個可以用來處理原生對象的庫。擁有自定義的構(gòu)建和模塊化的npm包,使得你可以只需要加載你需要的包。用戶也可以自定義方法或則使用插件處理特殊情況。

image

6. Lazy

擁有5K個stars,lazy.js是一個函數(shù)式的JavaScript庫。該庫的底層的實(shí)現(xiàn)都是懶執(zhí)行的,也就是說盡量不做運(yùn)算,除非真的需要。這個庫不依賴第三方庫,這里有一個demo,這里是API文檔

比如,我們要生成300個1到1000之間完全不同的隨機(jī)數(shù),可以這樣寫:

Lazy.generate(Math.random)
  .map(function(e) { return Math.floor(e * 1000) + 1; })
  .uniq()
  .take(300)
  .each(function(e) { console.log(e); });

如果用JavaScript直接去寫,代碼就會復(fù)雜很多了。

7. CollectJS

擁有超過3.5K個stars,collect.js是一個非常有前景并且不依賴于任何第三方庫。它提供了針對數(shù)組和對象的包裝,使用非常方便。

const collection = collect([{
  name: 'JavaScript: The Good Parts', pages: 176
}, {
  name: 'JavaScript: The Definitive Guide', pages: 1096
}]);

collection.avg('pages');

//=> 636

8. ChanceJS

Chance是一個用來隨機(jī)生成字符串、數(shù)字等的函數(shù),他可以減少一些偽隨機(jī)性,在你需要寫自動化測試或則其它你需要生成隨機(jī)數(shù)據(jù)的地方很有用。雖然只有3K個stars,但是這個庫真的非常方便。

image

9. ChartJS

擁有超過40K個stars,chart.js是一個少即是多的的經(jīng)典例子。它只提供了8中可視化的類型,每一種都有動畫并且可以自定義。Chart.js讓你可以使用<canvas>標(biāo)簽來作圖,并且在不同的瀏覽器上高效渲染。

image

10. Polished

擁有超過3.5K個stars,由styled-components團(tuán)隊(duì)開發(fā),Polished是一個用于寫css樣式的工具集,提供sass風(fēng)格的幫助函數(shù)和mixins。該庫和styled-components,Aphrodite,Radium兼容。

11. Mout

Mout.js是一個JavaScript的模塊化工具集合,能夠以AMD模塊的形式在瀏覽器或者Node.js中使用。Mout.js讓你可以只加載你需要的模塊或者函數(shù),如下所示:

// you can load individual methods (recommended)
var map = require('mout/array/map');
map([1, 2], function(v){ return val * val; }); // [1, 4]

// a single package
var stringUtils = require('mout/string');
stringUtils.camelCase('Foo Bar'); // "fooBar"

// or the whole lib
var mout = require('mout');
console.log( mout.math.clamp(17, 0, 10) ); // 10

12. Voca

一個用于處理字符串的JavaScript庫,包含了很多的幫助函數(shù),比如:change case, trim, pad, slugify, latinise, sprintf‘y, truncate, escape等等。

13. Licia

雖然只有500來個stars,但是Licia提供了非常多的工具函數(shù),對于日常使用非常有幫助。
官方介紹:

Licia是一套在開發(fā)中實(shí)踐積累起來的實(shí)用JavaScript工具庫。該庫目前擁有超過180個模塊,包括Dom操作,cookie設(shè)置,類創(chuàng)建,模板函數(shù),日期格式化等實(shí)用模塊,同時配套有打包工具Eustia進(jìn)行定制化,使JS腳本加載量縮減在10KB以下,極大優(yōu)化移動端頁面的加載速度。

image

Licia由RedHood開發(fā),詳細(xì)了解可以查看他本人在知乎上寫的對Licia的介紹: 超實(shí)用JavaScript工具庫

關(guān)于Fundebug

Fundebug專注于前端網(wǎng)頁H5、微信小程序、微信小游戲、支付寶小程序、React Native、Node.js和Java實(shí)時BUG監(jiān)控。

自從2016年雙十一正式上線,F(xiàn)undebug累計(jì)處理了6億+錯誤事件,目前付費(fèi)用戶有Google中國、360、金山軟件、荔枝FM、艾瑞咨詢、百姓網(wǎng)等眾多明星企業(yè)。歡迎免費(fèi)試用!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容