翻譯:瘋狂的技術宅
原文:
https://www.edureka.co/blog/t...
本文首發微信公衆號:前端先鋒
歡迎關注,天天都給你推送新鮮的前端技術文章javascript
多年來,業界已經發布了大量 JavaScript 框架,怎樣進行選擇多是一個挑戰。若是你感到困惑,不知道應該選哪一個或者究竟哪一個適合你,那麼我已經幫你解決了問題。在本文中,我將列出用來構建 Web 應用程序的前10個 JavaScript 框架。前端
10. Aurelia
Aurelia 是一個開源的現代 JavaScript 模塊工具箱,其有助於 Web 和移動應用程序的發展。它也被稱爲「下一代框架」。該框架自推出以來一直受到普遍承認。 Fileee、Freska、Ordami 和 BTEK Software 等公司以及800多個網站都使用了 Aurelia。java
不要忘記,Aurelia 是惟一容許開發人員使用原生 TypeScript 或 JavaScript 構建組件的框架。程序員
下面我列出了 Aurelia 的一些主要功能:面試
- 多語言支持:Aurelia 的 API 通過精心設計,能夠用於當今和將來最實用的 Web 編程語言。 Aurelia 支持 ES五、ES201五、ES2016 和 Typescript,它很是有用,並可以爲你提供高度的靈活性。
- 模塊框架:Aurelia 不是採用單一框架的方式,而是由較小的、專一的模塊組成。把它們放在一塊兒能夠組成功能齊全的框架,也能夠經過自定義構建可選擇的方案。
- 整潔的文檔:Aurelia 提供了一個很是詳細並有用的文檔集,能夠幫助全部的開發人員。它以良好的文檔維護而聞名。
- 可擴展的 HTML:Aurelia 的可擴展 HTML 編譯器容許你建立自定義 HTML 元素,能夠向現有元素中添加自定義屬性並控制模板生成,全部這些都徹底支持動態加載、數據綁定和高性能批量渲染。
9. Polymer
Polymer 是一個由 Google 維護的開源 JavaScript 庫,用於使用 Web 組件構建 Web 應用。目前,有超過3000個網站正在使用聚合物,好比virustotal.com、rogers.com、zeplin.io等。數據庫
與其餘 JavaScript 框架不一樣,Polymer 讓開發人員構建組件時去利用 Web 中存在的功能。它是第一個利用 Web 組件來對應用進行交互式構建的庫。編程
Polymer 的關鍵特性:segmentfault
- Web 組件:Polymer 構建在 Web 組件的思想之上。 Web 組件是一組 w3c 標準,由幾種不一樣的 Web 技術組成,其中包括自定義元素。這些組件是瀏覽器的一部分,因此你不須要任何第三方工具和庫,好比 jQuery。
- 單向和雙向數據綁定:它提供單向和雙向數據綁定。Polymer 旨在支持在單向和雙向流動的數據。
- 本機瀏覽器:Polymer 使用本機瀏覽器技術,而不是依賴於自定義 JavaScript 庫。Polymer 的 DOM 層最接近本機 JavaScript 層。
- 自定義元素:它容許使用 HTML、CSS 和 JavaScript 輕鬆建立自定義元素,以便向元素添加交互。 Polymer.js 提供了建立自定義 HTML 元素的最簡單方法,由於它的庫是基於 Web 標準 API 構建的。
8. Meteor
Meteor 是一個用 NodeJS 編寫的免費開源 JavaScript 框架。它容許進行快速原型設計並生成跨平臺代碼。它在市場上愈來愈受歡迎,超過 13,000 個網站使用了 Meteor。像mtv.com、meteofrance.com等網站利用 Meteor 來構建他們的用戶界面。後端
Meteor 的主要特性:瀏覽器
- 全棧:Meteor 爲開發和部署 Web 應用提供了全棧解決方案。 Meteor 捆綁了幾個內置功能,如反應式模板、自動 CSS 等。
- 智能包:爲你的應用開發登陸系統可能會很麻煩。但 Meteor 不會。 Meteor 軟件包能夠輕鬆添加用戶賬戶,還有 React 之類的 JavaScript 庫等。最好方便的是,添加這些類型的智能包很容易,只需在終端中敲幾下鍵盤就能夠了。
- 實時網絡應用:Meteor 是構建實時程序的完美解決方案。從數據庫到模板全部的層都會自動更新。這意味着無需刷新頁面便可查看更新。對文檔的任何修改都會當即保存。這使得 Meteor 成爲實時協做的完美解決方案。
- 單一語言開發:Meteor 容許在前端和後端使用相同的代碼,可用於移動和 Web 應用。它能夠杜絕安裝和配置不一樣的庫、模塊管理器、API、驅動程序等。這大大的節省了開發人員的時間,由於他們不須要在服務器語言和 JavaScript 之間執行上下文切換。
7. Ember
Ember是一個開源的 JavaScript Web 框架,它容許開發人員經過將最佳實踐合併到框架中來構建可伸縮的單頁面 Web 應用。 Ember 被評爲最佳的 JavaScript 客戶端框架,其主要競爭對手是 React 和 AngularJS。目前超過 6000 個網站正在使用 ember。僅舉幾例:nasa.gov、tutorialspoint.com 等。
Ember 的一些主要特性:
- Web開發的將來:在 Babel JavaScript 轉換器的幫助下,Ember 容許開發人員使用將來的 JavaScript 標準並將其進行轉換爲目前瀏覽器支持的代碼。不知道 Babel 是什麼? Babel 是一個 JavaScript 轉換器,容許開發人員如今使用下一代 JavaScript 代碼。另外 Babel 受益於衆多插件,而且與 Ember、Rails、Sails 和 Meteor 等框架兼容。
- Ember cli:Ember 和 Ember-CLI 徹底是兩個不一樣的東西,但若是沒有另外一個則二者都不完整。 Ember-CLI 是一個命令行實用程序,它與 Ember 框架的軟件棧一塊兒提供。 Ember-CLI 是一種強大的生產力工具,支持CoffeeScript、Handlebars、LESS 和 Sass 等。
- Ember 模板:Ember 的模板內置於 Ember 的 UI 中,這些模板使用 Handlebars 模板語言編寫。 Handlebars 以其使用雙花括號命名,它可使開發人員寫更少的代碼。模板在 Ember 中提供了許多功能,例如組件、插口和表達式等。
- CoC:它的惟一目的是速度和「把事情搞定」的理念,這對於那些老是努力超越競爭對手的初創公司來講是一個巨大的推進力。Ember 有關於其結構的最佳實踐,這意味着開發人員能夠更專一於實現業務,而不是經過繁瑣的代碼從新發明輪子。有更多的成果,而不是藍圖。
6. NodeJS
Node.js 是一個基於 Google Chrome 的 JavaScript 引擎構建的開源服務器端平臺。使用 NodeJS 的網站數量已超過 84,000 個。它是下載量最大的用於執行 JavaScript 代碼的跨平臺運行時環境之一。
Node.js 的主要特性:
- 非阻塞:Node.js 庫的全部API都是異步的,即非阻塞的。這意味着基於 Node.js 的服務器永遠不會等待 API 返回數據。服務器在調用它以後移動到下一個 API,而且事件的通知機制幫助服務器從先前的 API 調用得到響應。
- 單線程:Node.js 使用帶有事件循環的單線程模型。事件機制可幫助服務器以非阻塞方式響應,從而使服務器具備高度可伸縮性,而傳統服務器則建立有限的線程來處理請求。與 Apache HTTP Server 等傳統服務器相比,Node.js 使用的單線程程序能夠爲更多的請求提供服務。
- 快速:NodeJS 創建在Google Chrome 的 V8 引擎之上。 Google 的 V8 引擎確保 Node.js 庫以極快的速度執行其代碼。
- 數據流:NodeJS 程序從不緩衝任何數據,它們只是以數據塊的形式輸出數據。這樣 NodeJS 能夠提供更快的服務。
5. BackboneJS
BackboneJS 是一個輕量級 JavaScript 庫,用來開發和構建在 Web 瀏覽器中運行的客戶端應用。與其餘框架不一樣,Backbone 讓開發人員負責選擇最適合當前項目的工具。目前,超過50萬個網站正在使用 Backbone,其中包括tumblr.com、espn.com、soundcloud.com等等。
Backbone 的主要特性:
- 分離的業務和UI邏輯:Backbone 能夠幫助你把本身的業務邏輯與用戶界面分開,這是很是重要的一點。當二者糾纏在一塊兒時,修改將會變得很難。當邏輯不依賴於 UI 時,你的界面會變得更加易用。
- 事件驅動的通訊:當項目不斷增加時,jQuery 聲明和回調將變得更加複雜,代碼變得更加混亂。 Backbone.js 經過在視圖和模型之間提供事件驅動的通訊來克服這個問題。
- 更少的代碼:約定是引入通用編碼風格的好方法,而無需提供大量的編碼標準。你遵照的 backbone 約定越多,編寫代碼的次數就越少,反過來代碼也會變得更加標準化,並具備可讀性。
- 與後端同步:因爲其對 RESTful API 的出色支持,BackboneJS 中的模型能夠輕鬆地與後端綁定。若是 API 設計正確,則 backbone 能夠直接經過訪問這些操做來進行讀取、寫入和刪除操做。
4. jQuery
Jquery 是最古老的 JS 框架之一。這個框架已經存在了 13 年之久,並且它仍然很強大。那麼什麼是 jQuery?
jQuery 是一個快速而簡潔的 JavaScript 庫,由 John Resig 在2006年建立,它有一個很好宗旨:寫得少,作得多。它是一個跨瀏覽器的 JavaScript 庫,旨在簡化 HTML 的客戶端腳本。目前有超過 1900 萬個網站正在使用jQuery!WordPress、Facebook、Google、IBM 和其餘許多公司都依賴 jQuery 提供獨一無二的網絡瀏覽體驗。
jQuery的主要特性:
- DOM操做:它使對 DOM 的操做變得很是容易,使開發人員能夠經過易於學習的API(基於頂層 JavaScript)充分利用他們的創造力來建立使人驚歎的東西。
- 大型社區:其貢獻者的社區比任何其餘 JavaScript 庫更加龐大和多樣化。它有普遍而全面的文檔支持,不要忘記,它會不斷獲得維護,而且會愈來愈強大。
- AJAX支持:簡而言之,AJAX(異步 JavaScript 和 XML)是關於在後臺加載數據並將其顯示在網頁上,而無需從新加載整個頁面的技術。 jQuery 爲 AJAX 功能提供了好幾種方法。經過 jQuery AJAX,你能夠用 HTTP Get 和 HTTP Post 從遠程服務器請求文本、HTML、XML或JSON。
- 跨瀏覽器支持:jQuery 具備跨瀏覽器支持特性,適用於 IE 6.0 +,FF 2.0 +,Safari 3.0 +,Chrome 和 Opera 9.0+等。
3. Vue
Vue是一個用於構建 UI 的開源 JavaScript 框架。因爲它的設計具備適應性,Vue 簡化了與其餘 JavaScript 庫的項目集成。目前超過 36,000 個網站正在使用 Vue。像 stackoverflow、playstation 等公司依賴 Vue 開發他們的網站界面。
VueJS的主要特性:
- 模板:Vue.js 提供基於 HTML 的模板,將 DOM 與 Vue.js 實例數據綁定。 Vue.js 將模板編譯爲虛擬 DOM 渲染函數。 Web 開發人員可使用渲染函數的模板,並可使用渲染函數替換模板。
- 體積小:JavaScript 框架的成功取決於它的大小。個頭越小用的人越多。 Vue.js 最大的優點之一是體積小。該框架的大小爲 18-21 KB。
- 適應性:Vue 容許用戶用虛擬節點把模版寫在 HTML 文件、JavaScript 文件和純 JavaScript 文件中。這種靈活性還容易讓使用 React.js,Angular.js 和任何其餘新 JavaScript 框架的開發人員理解。它基於 JavaScript 框架,能夠集成到基於 JavaScript 構建的其餘程序中。
- 詳細的文檔:開發人員老是喜歡使用帶有詳細文檔的框架,由於他們老是很容易編寫本身的第一個應用程序。Vue.js 的文檔很是全面,任何對 JavaScript 和 HTML 有所瞭解的用戶均可以用它開發本身的應用或網頁。
2. ReactJS
React 是 Facebook 維護的另外一個 JavaScript 庫,用於構建交互式和複雜的 UI。它是最熱門的框架之一,有超過 3 萬個網站使用 React 實現 UI。舉幾個網站:Microsoft.com、yahoo.com 等。
ReactJS 的主要特性:
- Virtual DOM:在React中,對於每一個 DOM 對象,都有一個對應的「虛擬 DOM 對象」。虛擬 DOM 對象建立原始 DOM 的虛擬副本。這是一種單向數據綁定,因爲修改時不須要實時向屏幕渲染,所以操做虛擬 DOM 比更新原始 DOM 快不少。
- JSX:React 使用了 JSX,這是一個使用 HTML 引用的簡單 JavaScript,而不是用於模板的 JavaScript。你也可使用 HTML 語法來渲染子組件,或使用老式的 JavaScript 編寫,這意味着不管採用哪一種方式,你均可以靈活地進行編碼。
- 單向數據流:React.js 的設計方式使其只支持在一個流程中向下遊傳遞的數據。若是數據必須向另外一個方向流動,則須要其餘功能支持。
- 組件:在React中,全部內容都被視爲組件,所以你能夠輕鬆導入 React 支持的組件,而不是編碼或構建整個功能,你能夠方便的導入並使用它。
1. AngularJS
Angular 是最強大、最高效、最開源的 JavaScript 框架之一。在這個列表中不可能不說起 Angular。該框架由Google 運營,用於開發單頁應用(SPA)。這個開發框架之因此出名,主要是由於它爲開發人員提供了將JavaScript 與 HTML 和 CSS 結合起來的最佳條件。有超過五十萬個網站如 google.com、youtube.com 等正在使用 Angular。
Angular 的主要特性:
本文首發微信公衆號:前端先鋒
歡迎掃描二維碼關注公衆號,天天都給你推送新鮮的前端技術文章
歡迎繼續閱讀本專欄其它高贊文章: