1. 程式人生 > >2018 年你需要知道的 11 個 JavaScript 庫

2018 年你需要知道的 11 個 JavaScript 庫

譯者按:你可能已經用到Underscore或者Lodash。本文列舉了11個常用的庫來提高開發效率。

為了保證可讀性,本文采用意譯而非直譯。另外,本文版權歸原作者所有,翻譯僅用於學習。

JavaScript依然是2018年最受歡迎、最流行的程式語言,所以它的生態系統也十分完善。

640?wx_fmt=png

JavaScript小小的標準庫不足以應付各種開發需求。在Github上,有許多流行的JavaScript庫。在這裡,我整理了一個列表推薦給大家:

1. Underscore & Lodash (dah)

也許大多數童鞋都已經知道它們。Underscore提供了日常使用的基礎函式。Lodash, 作為NPM最多下載量和被依賴最多的包,提供了更加支援跨環境一致性的對陣列、字串、物件和引數物件的支援。它已經是Underscore的超集。Underscore和Lodash有同一組核心開發者維護。你日常開發中絕對少不了要用到它。

  • Lodash:https://github.com/lodash/lodash

  • Underscore:https://github.com/jashkenas/underscore

2. Ramda

擁有超過12K的stars,Ramda庫可以用來在JavaScript中函數語言程式設計,專門為函數語言程式設計風格而設計,更容易建立函式式 pipeline、且從不改變使用者已有資料。

摘自官方:

Ramda 主要特性如下:

  • Ramda 強調更加純粹的函式式風格。資料不變性和函式無副作用是其核心設計理念。這可以幫助你使用簡潔、優雅的程式碼來完成工作。

  • Ramda 函式本身都是自動柯里化的。這可以讓你在只提供部分引數的情況下,輕鬆地在已有函式的基礎上建立新函式。

  • Ramda 函式引數的排列順序更便於柯里化。通常最後提供要操作的資料。

最後兩點一起,使得將多個函式構建為簡單的函式序列變得非常容易,每個函式對資料進行變換並將結果傳遞給下一個函式。Ramda 的設計能很好地支援這種風格的程式設計。

  • Ramda:https://github.com/ramda/ramda

你也可以看看:immutable.js(https://github.com/facebook/immutable-js/

3. MathJS

擁有超過6K的stars,Math.js是一個Node.js和JavaScript的math擴充套件庫,並且和內建的Math庫相容。該庫中包含一個靈活的表示式分析器,並且有非常多的內建函式可以使用。你甚至可以自行做擴充套件。


  • Math.js:https://github.com/josdejong/mathjs

4. Moment/date-fns

擁有超過40K的stars,moment.js是一個JavaScript的時間處理庫,可以用來分析、驗證、處理和格式化時間。Moment被設計可以用於瀏覽器和Node.js環境下。對於V2.10.0,程式碼完全用ECMAScript 6模組實現。

Date-fns也是一個非常流行(超過11K的stars)的時間處理庫,提供超過130多個函式,很多人把它當做moment.js(檢視對比:https://github.com/date-fns/date-fns/issues/275#issuecomment-264934189)的替代品。Date-fns完全用純函式實現,並保證不可修改性。它可以很好的和webpack,Browserify、或Rollup配合使用,並支援tree-shaking。

  • moment:https://github.com/moment/moment/

  • date-fns:https://github.com/date-fns/date-fns

5. Sugar

擁有超過3.5K個stars,Sugar是一個可以用來處理原生物件的庫。自定義的構建和模組化的npm包,使得你可以只需要載入你需要的包。使用者也可以自定義方法或則使用外掛處理特殊情況。

  • Sugar:https://github.com/andrewplummer/Sugar

640?wx_fmt=png


6. Lazy

擁有5K個stars,lazy.js是一個函式式的JavaScript庫。該庫的底層的實現都是懶執行的,也就是說盡量不做運算,除非站的需要。這個庫不依賴第三方庫,這裡有一個demo(http://danieltao.com/lazy.js/demos/events/),這裡是API文件(http://danieltao.com/lazy.js/)。

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

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

用JavaScript直接去寫,程式碼就會複雜很多了。

  • lazy.js:https://github.com/dtao/lazy.js

7. CollectJS

擁有超過3.5K個stars,collect.js是一個非常有前景並且不依賴於任何第三方庫的庫。它提供了針對陣列和物件的包裝,使用非常方便。

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

collection.avg('pages');

//=> 636
  • collect.js:https://github.com/ecrmnn/collect.js/


8. ChanceJS

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

640?wx_fmt=png

  • chancejs:https://github.com/chancejs/chancejs

9. ChartJS

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

  • chart.js:https://github.com/chartjs/Chart.js

640?wx_fmt=png

10. Polished

擁有超過3.5K個stars,由styled-components(https://github.com/styled-components/styled-components)團隊開發,Polished是一個用於寫css樣式的工具集,提供saas風格的幫助函式和mixins。該庫和styled-components,Aphrodite,Radium相容。

  • polished:https://github.com/styled-components/polished

11. Mout

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

// you can load individual methods (recommended)
var map = require('mout/array/map');
map([12], 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(17010) ); // 10
  • mout:https://github.com/mout/mout

其他

Voca

一個用於處理字串的JavaScript庫,包含了很多的幫助函式,比如:change case, trim, pad, slugify, latinise, sprintf‘y, truncate, escape等等。

  • voca:https://github.com/panzerdp/voca

Licia

雖然只有500來個stars,但是Licia提供了非常多的工具函式,對於日常使用非常有幫助。

官方介紹:

Licia是一套在開發中實踐積累起來的實用JavaScript工具庫。該庫目前擁有超過180個模組,包括Dom操作,cookie設定,類建立,模板函式,日期格式化等實用模組,同時配套有打包工具Eustia進行定製化,使JS指令碼載入量縮減在10KB以下,極大優化移動端頁面的載入速度。

640?wx_fmt=jpeg

Licia由RedHood(https://www.surunzi.com/)開發,詳細瞭解可以檢視他本人在知乎上寫的對Licia的介紹: 超實用JavaScript工具庫(https://zhuanlan.zhihu.com/p/25502829)。

  • licia:https://github.com/liriliri/licia

來源:https://blog.fundebug.com/2018/07/02/11-js-utility-you-should-know-in-2018/

原文:11 Javascript Utility Libraries You Should Know In 2018(https://blog.bitsrc.io/11-javascript-utility-libraries-you-should-know-in-2018-3646fb31ade)

翻譯:Fundebug

640?wx_fmt=png

選擇置頂,關鍵時刻

第一時間送達! 

640?wx_fmt=jpeg

長按二維碼關注