前端Js框架彙總
概述:
有些日子沒有正襟危坐寫博客了,互聯網飛速發展的時代,技術更新迭代的速度也在加快。看着Java、Js、Swift在各領域心花路放,也是煞是羨慕。尋了尋.net的消息,也是振奮人心,.net core 1,mono,xamarin等等,但大多都還在狂吼的階段。其實一直以來對技術的理解是技術服務於業務和產品,產品又在不一樣程度的推動着技術的演進。
Web、無線、物聯網、VR、PC從不一樣方向推動着技術的融合與微創新。程序員在不一樣業務場景下的角色互換。而隨着node.js的出現語言的角色也在發生着轉變,Js扮演了愈來愈重要的角色。也就有了茶餘飯後也把了解到的知識整理一下。看過「你的知識須要管理」後,強烈的意識到雜亂且範範的知識儲備遠不如整理後條理清晰的知識帶來好處多。因此,是的,咱們須要時不時的回來對掌握的知識梳理歸類,以備不時之需。
1、前端框架庫:
1.Zepto.js
地址:http://www.css88.com/doc/zeptojs/
描述:Zepto是一個輕量級的針對現代高級瀏覽器的JavaScript庫, 它與jquery有着相似的api。 若是你會用jquery,那麼你也會用zepto。關於Zepto認知我也是經過與一位騰訊朋友聊天的時候知道的,只做了些基礎的瞭解。
2.SUI Mobile
地址:http://m.sui.taobao.org
描述:SUI Mobile 是一套基於 Framework7 開發的UI庫。它很是輕量、精美,只須要引入咱們的CDN文件就可使用,而且能兼容到 iOS 6.0+ 和 Android 4.0+,很是適合開發跨平臺Web App。
用途:你也看到了,他是用於無線端的Web App的開發。
3.Node.Js
地址:http://www.runoob.com/nodejs/nodejs-tutorial.html (中文網)
描述:Node.js是一個Javascript運行環境(runtime)。實際上它是對Google V8引擎進行了封裝。V8引 擎執行Javascript的速度很是快,性能很是好。Node.js對一些特殊用例進行了優化,提供了替代的API,使得V8在非瀏覽器環境下運行得更好。
Node.js是一個基於Chrome JavaScript運行時創建的平臺, 用於方便地搭建響應速度快、易於擴展的網絡應用。Node.js 使用事件驅動, 非阻塞I/O 模型而得以輕量和高效,很是適合在分佈式設備上運行數據密集型的實時應用。
簡單的說 Node.js 就是運行在服務端的 JavaScript。
Node.js 是一個基於Chrome JavaScript 運行時創建的一個平臺。
Node.js是一個事件驅動I/O服務端JavaScript環境,基於Google的V8引擎,V8引擎執行Javascript的速度很是快,性能很是好。
用途:
1. RESTful API
這是NodeJS最理想的應用場景,能夠處理數萬條鏈接,自己沒有太多的邏輯,只須要請求API,組織數據進行返回便可。它本質上只是從某個數據庫中查找一些值並將它們組成一個響應。因爲響應是少許文本,入站請求也是少許的文本,所以流量不高,一臺機器甚至也能夠處理最繁忙的公司的API需求。
2. 統一Web應用的UI層
目前MVC的架構,在某種意義上來講,Web開發有兩個UI層,一個是在瀏覽器裏面咱們最終看到的,另外一個在server端,負責生成和拼接頁面。
不討論這種架構是好是壞,可是有另一種實踐,面向服務的架構,更好的作先後端的依賴分離。若是全部的關鍵業務邏輯都封裝成REST調用,就意味着在上層只須要考慮如何用這些REST接口構建具體的應用。那些後端程序員們根本不操心具體數據是如何從一個頁面傳遞到另外一個頁面的,他們也不用管用戶數據更新是經過Ajax異步獲取的仍是經過刷新頁面。
3. 大量Ajax請求的應用
例如個性化應用,每一個用戶看到的頁面都不同,緩存失效,須要在頁面加載的時候發起Ajax請求,NodeJS能響應大量的併發請求。 總而言之,NodeJS適合運用在高併發、I/O密集、少許業務邏輯的場景。
4.angular.Js
地址:http://www.runoob.com/angularjs/angularjs-tutorial.html (中文網)
描述:AngularJS[1] 誕生於2009年,由Misko Hevery 等人建立,後爲Google所收購。是一款優秀的前端JS框架,已經被用於Google的多款產品當中。AngularJS有着諸多特性,最爲核心的是:MVVM、模塊化、自動化雙向數據綁定、語義化標籤、依賴注入等等。
用途:經過描述咱們應該就能很好的明白AngularJS的真實用途了,MVVM,模塊化,自動化雙向數據綁定等等。除了簡單的dom操做外,更能體現Js編程的強大。固然應用應該視場合而定。
5.JQuery Mobile
地址:http://www.w3school.com.cn/jquerymobile/ (中文網)
描述:Query Mobile是jQuery 在手機上和平板設備上的版本。jQuery Mobile 不只會給主流移動平臺帶來jQuery核心庫,並且會發佈一個完整統一的jQuery移動UI框架。支持全球主流的移動平臺。jQuery Mobile開發團隊說:能開發這個項目,咱們很是興奮。移動Web太須要一個跨瀏覽器的框架,讓開發人員開發出真正的移動Web網站。
用途:jQuery Mobile 是建立移動 web 應用程序的框架。
jQuery Mobile 適用於全部流行的智能手機和平板電腦。
jQuery Mobile 使用 HTML5 和 CSS3 經過儘量少的腳本對頁面進行佈局。
6.requirejs
地址:http://www.requirejs.cn/
描述:RequireJS的目標是鼓勵代碼的模塊化,它使用了不一樣於傳統<script>標籤的腳本加載步驟。能夠用它來加速、優化代碼,但其主要目的仍是爲了代碼的模塊化。它鼓勵在使用腳本時以module ID替代URL地址。
RequireJS以一個相對於baseUrl的地址來加載全部的代碼。 頁面頂層<script>標籤含有一個特殊的屬性data-main,require.js使用它來啓動腳本加載過程,而baseUrl通常設置到與該屬性相一致的目錄。
用途:模塊化動態加載。
7.Vue.js
地址:http://cn.vuejs.org/
描述:Vue.js 是用於構建交互式的 Web 界面的庫。它提供了 MVVM 數據綁定和一個可組合的組件系統,具備簡單、靈活的 API。從技術上講, Vue.js 集中在 MVVM 模式上的視圖模型層,並經過雙向數據綁定鏈接視圖和模型。實際的 DOM 操做和輸出格式被抽象出來成指令和過濾器。相比其它的 MVVM 框架,Vue.js 更容易上手。
8.backbone.js
地址:http://www.css88.com/doc/backbone/
描述:Backbone 爲複雜Javascript應用程序提供模型(models)、集合(collections)、視圖(views)的結構。其中模型用於綁定鍵值數據和自定義事件;集合附有可枚舉函數的豐富API; 視圖能夠聲明事件處理函數,並經過RESTful JSON接口鏈接到應用程序。
9.React
地址:http://reactjs.cn/react/docs/why-react.html
描述:React 是一個 Facebook 和 Instagram 用來建立用戶界面的 JavaScript 庫。不少人認爲 React 是 MVC 中的 V(視圖)。咱們創造 React 是爲了解決一個問題:構建隨着時間數據不斷變化的大規模應用程序。爲了達到這個目標,React 採用下面兩個主要的思想。
10.Ionic
地址:http://www.ionic.wang/js_doc-index.html
描述:Ionic既是一個CSS框架也是一個Javascript UI庫。許多組件須要Javascript才能產生神奇的效果,儘管一般組件不須要編碼,經過框架擴展能夠很容易地使用,好比咱們的AngularIonic擴展。
Ionic遵循視圖控制模式,通俗的理解和 Cocoa 觸摸框架類似。在視圖控制模式中,咱們將界面的不一樣部分分爲子視圖或包含其餘視圖的子視圖控制器。而後視圖控制器「驅動」內部視圖來提供交互和UI功能。一個很好的例子就是標籤欄(Tab Bar)視圖控制器處理點擊標籤欄在一系列可視化面板間切換。
瀏覽咱們的API文檔來了解視圖控制器和Ionic中可用的Javascript實用工具。
Ionic 是目前最有潛力的一款 HTML5 手機應用開發框架。經過 SASS 構建應用程序,它 提供了不少 UI 組件來幫助開發者開發強大的應用。 它使用 JavaScript MVVM 框架和 AngularJS 來加強應用。提供數據的雙向綁定,使用它成爲 Web 和移動開發者的共同選擇。
2、前端UI框架
1.Pure
地址:http://purecss.org/layouts/
描述:Pure精心設計,只爲能夠在任何Web項目中使用。爲了例證這一點,咱們製做了以下幾個模板。這些模板都是響應式的,而且沒有使用任何JavaScript。
用途:真的是很精美的一個樣式框架,便於咱們快事構建一些我的產品,固然也能夠服務於工做中的一些項目。
2.bootstrap
地址:http://www.bootcss.com/
描述:簡潔、直觀、強悍的前端開發框架,讓web開發更迅速、簡單。
3.EasyUI
地址:http://www.jeasyui.net/ (中文網)
描述:easyui是一種基於jQuery的用戶界面插件集合。
easyui爲建立現代化,互動,JavaScript應用程序,提供必要的功能。
使用easyui你不須要寫不少代碼,你只須要經過編寫一些簡單HTML標記,就能夠定義用戶界面。
easyui是個完美支持HTML5網頁的完整框架。
easyui節省您網頁開發的時間和規模。
easyui很簡單但功能強大的。
4.Ant Design
地址:http://ant.design/
描述:一個 UI 設計語言,一套提煉和應用於企業級後臺產品的交互語言和視覺體系
3、可視化組件
1.Echarts
地址:http://echarts.baidu.com/
描述:ECharts,一個純 Javascript 的圖表庫,能夠流暢的運行在 PC 和移動設備上,兼容當前絕大部分瀏覽器(IE8/9/10/11,Chrome,Firefox,Safari等),底層依賴輕量級的 Canvas 類庫ZRender,提供直觀,生動,可交互,可高度個性化定製的數據可視化圖表。
2.tableau(收費)
地址:http://www.yuandingit.com/special/tableau/index.html
描述:Tableau 是桌面系統中最簡單的商業智能工具軟件,Tableau 沒有強迫用戶編寫自定義代碼,新的控制檯也可徹底自定義配置。在控制檯上,不只可以監測信息,並且還提供完整的分析能力。Tableau控制檯靈活,具備高度的動態性。
4、前端構建工具
1.gulp
地址:http://www.gulpjs.com.cn/
描述:易於使用
經過代碼優於配置的策略,Gulp 讓簡單的任務簡單,複雜的任務可管理。
構建快速
利用 Node.js 流的威力,你能夠快速構建項目並減小頻繁的 IO 操做。
插件高質
Gulp 嚴格的插件指南確保插件如你指望的那樣簡潔高質得工做。
易於學習
經過最少的 API,掌握 Gulp 絕不費力,構建工做盡在掌握:如同一系列流管道。
5、博客搭建
1.技術組合
HEXO+Github,搭建屬於本身的博客。
站點:http://www.jianshu.com/p/465830080ea9
HEXO介紹:Hexo是一個開源的靜態博客生成器,用node.js開發,做者是臺灣大學生tommy351
準備:git + node.js + markdown編輯 + gitcafe + 域名
小結:本文作爲知識梳理或者說資料梳理類文章,一方面用於自身知識的管理,同時也能夠用作一個資料庫備查。將持續更新。
css