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

来源:https://www.cnblogs.com/fundebug/archive/2018/08/14/13_js_utilities_you_need.html
-Advertisement-
Play Games

你可能已經用到Underscore或者Lodash。本文列舉了13個常用的JavaScript工具庫來提高開發效率。 ...


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

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

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

 

 

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

1. Underscore & Lodash

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

2. Ramda

擁有超過12K的stars,Ramda庫可以用來在JavaScript中函數式編程,專門為函數式編程風格而設計,更容易創建函數式pipeline、且從不改變用戶已有數據。

摘自官方:

Ramda 主要特性如下:

  • Ramda 強調更加純粹的函數式風格。數據不變性和函數無副作用是其核心設計理念。這可以幫助你使用簡潔、優雅的代碼來完成工作。
  • Ramda 函數本身都是自動柯里化的。這可以讓你在只提供部分參數的情況下,輕鬆地在已有函數的基礎上創建新函數。
  • Ramda 函數參數的排列順序更便於柯里化。通常最後提供要操作的數據。

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

你也可以看看:immutable.js

3. MathJS

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

4. Moment & date-fns

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

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

5. Sugar

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

 

 

6. Lazy

擁有5K個stars,lazy.js是一個函數式的JavaScript庫。該庫的底層的實現都是懶執行的,也就是說儘量不做運算,除非真的需要。這個庫不依賴第三方庫,這裡有一個demo,這裡是API文檔

比如,我們要生成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直接去寫,代碼就會複雜很多了。

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

8. ChanceJS

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

9. ChartJS

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

 

 

10. Polished

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

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

12. Voca

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

13. Licia

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

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

 

  Licia由RedHood開發,詳細瞭解可以查看他本人在知乎上寫的對Licia的介紹: 超實用JavaScript工具庫。 

關於Fundebug

Fundebug專註於前端網頁H5、微信小程式、微信小游戲、支付寶小程式、React Native、Node.js和Java實時BUG監控。

自從2016年雙十一正式上線,Fundebug累計處理了6億+錯誤事件,目前付費用戶有Google中國、360、金山軟體、荔枝FM、艾瑞咨詢、百姓網等眾多明星企業。歡迎免費試用!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 刪除數組第一個元素使用var length = arr.shift(); 刪除arr的第一個元素後, 返回值是刪除後的數組長度 刪除數組最後一個元素使用var length = arr.pop(); 刪除arr的最後一個元素後, 返回值是刪除後數組的長度 在數組開頭添加元素使用var length ...
  • 一、前言 時隔三年,記得第一次寫博客還是2015年了,經過這幾年的洗禮,我也從一個後端的小萌新變成現在略懂一點點知識的文青。如今對於前端的東東也算有一知半解,個人能力總的來說,也能夠獨立開發產品級項目吧。至於為什麼會前端的東西,估計學.NET的人應該大部分都懂些,之前自己搭建過一套框架,但覺得現在的 ...
  • 用兩個伺服器處理一個項目的代碼,其中一臺伺服器只處理介面請求。 本來PHP可以使用CURL來處理,但是領導不允許使用PHP來處理數據。會影響網站的功能。如果介面端出現問題會導致整個網站或其頁面的崩潰,因此使用前端處理數據。就不會產生這種問題。 本文適用於知道跨域,但是不知道跨域為何物的程式員。 話不 ...
  • 使用上一篇文章(https://www.cnblogs.com/ljzc002/p/9353101.html)中提出的方法,編寫一個簡單的宇宙飛船3D模型,在這篇文章中對模型製作流程和數學計算步驟進行介紹,併為模型添加簡單的材質。 我們首先對3D模型的輪廓進行估計,然後製作一個擁有足夠多頂點的、與模 ...
  • HTML5 Audio標簽能夠支持wav, mp3, ogg, acc, webm等格式,但有個很重要的音樂文件格式midi(擴展名mid)卻在各大瀏覽器中都沒有內置的支持。不是所有的瀏覽器都支持MP3 OGG之類的,每個瀏覽器因為版權的問題支持的格式都是不一樣的。 瀏覽器和音頻相容性 瀏覽器製造商 ...
  • http://www.css88.com/archives/5206 根據該文章方法,放在react項目中發現並不能實現,仔細觀察發現原來react解析出來的css樣式中沒有了 這個樣式 : 然後即可實現。 ...
  • /* *//*reset*//* */* {box-sizing: border-box; -webkit-tap-highlight-color: rgba(0,0,0,0);}html { font-family: "Helvetica Neue", Helvetica, STHeiTi, Ar ...
  • 一.前情概要 註:(我使用的路由是react router4)     如下圖所示,我們需要在頁面切換時有一個過渡效果,這樣就不會使頁面切換顯得生硬,用戶體驗大大提升;     but the 問題是,react的路由動畫沒有vue那麼方便,在vue裡面寫幾個 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...