javascript
2018 年你需要知道的 11 个 JavaScript 库
譯者按:你可能已經用到Underscore或者Lodash。本文列舉了11個常用的庫來提高開發效率。
為了保證可讀性,本文采用意譯而非直譯。另外,本文版權歸原作者所有,翻譯僅用于學習。
JavaScript依然是2018年最受歡迎、最流行的編程語言,所以它的生態系統也十分完善。
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
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(e)?{?return?Math.floor(e?*?1000)?+?1;?})
??.uniq()
??.take(300)
??.each(function(e)?{?console.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,但是這個庫真的非常方便。
chancejs:https://github.com/chancejs/chancejs
9. ChartJS
擁有超過40K的stars,chart.js是一個少即是多的的經典例子。它只提供了8中可視化的類型,每一種都有動畫并且可以自定義。Chart.js讓你可以使用<canvas>標簽來作圖,并且在不同的瀏覽器上高效渲染。
chart.js:https://github.com/chartjs/Chart.js
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([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
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以下,極大優化移動端頁面的加載速度。
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
選擇置頂,關鍵時刻
第一時間送達!?
長按二維碼關注
總結
以上是生活随笔為你收集整理的2018 年你需要知道的 11 个 JavaScript 库的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 抗日战争为什么是持久战?
- 下一篇: 马克思列宁主义是毛泽东军事思想产生和发展