隨著時(shí)間和技術(shù)的發(fā)展,前端框架從jQuery一家獨(dú)大的情況,發(fā)展到現(xiàn)在的Angular、Vue、React三足鼎立的情況,三個(gè)框架各有優(yōu)略,也都是比較成熟,但是同樣也造成了讓人無(wú)從下手的感覺,不知該如何選擇.今天傳智播客就來(lái)說(shuō)說(shuō)如何選擇使用那個(gè)框架。
React :
1.聲明式設(shè)計(jì):React采用聲明范式,可以輕松描述應(yīng)用。
2.高效:React通過(guò)對(duì)DOM的模擬,最大限度地減少與DOM的交互。
3.靈活:React可以與已知的庫(kù)或框架很好地配合。
優(yōu)點(diǎn):
1. 速度快:在UI渲染過(guò)程中,React通過(guò)在虛擬DOM中的微操作來(lái)實(shí)現(xiàn)對(duì)實(shí)際DOM的局部更新。
2. 跨瀏覽器兼容:虛擬DOM幫助我們解決了跨瀏覽器問題,它為我們提供了標(biāo)準(zhǔn)化的API,甚至在IE8中都是沒問題的。
3. 模塊化:為你程序編寫?yīng)毩⒌哪K化UI組件,這樣當(dāng)某個(gè)或某些組件出現(xiàn)問題是,可以方便地進(jìn)行隔離。
4. 單向數(shù)據(jù)流:Flux是一個(gè)用于在JavaScript應(yīng)用中創(chuàng)建單向數(shù)據(jù)層的架構(gòu)5. 同構(gòu)、純粹的javascript:因?yàn)樗阉饕娴呐老x程序依賴的是服務(wù)端響應(yīng)而不是JavaScript的執(zhí)行,預(yù)渲染你的應(yīng)用有助于搜索引擎優(yōu)化。6.兼容性好:比如使用RequireJS來(lái)加載和打包,而Browserify和Webpack適用于構(gòu)建大型應(yīng)用。它們使得那些艱難的任務(wù)不再讓人望而生畏。缺點(diǎn):React本身只是一個(gè)V而已,并不是一個(gè)完整的框架,所以如果是大型項(xiàng)目想要一套完整的框架的話,基本都需要加上ReactRouter和Flux才能寫大型應(yīng)用。
Vue:
Vue是尤雨溪編寫的一個(gè)構(gòu)建數(shù)據(jù)驅(qū)動(dòng)的Web界面的庫(kù),準(zhǔn)確來(lái)說(shuō)不是一個(gè)框架,它聚焦在V(view)視圖層。
它有以下的特性:
1.輕量級(jí)的框架
2.雙向數(shù)據(jù)綁定
3.指令
4.插件化
優(yōu)點(diǎn):
1. 簡(jiǎn)單:官方文檔很清晰,比 Angular 簡(jiǎn)單易學(xué)。
2. 快速:異步批處理方式更新 DOM。
3. 組合:用解耦的、可復(fù)用的組件組合你的應(yīng)用程序。
4. 緊湊:~18kb min+gzip,且無(wú)依賴。
5. 強(qiáng)大:表達(dá)式 無(wú)需聲明依賴的可推導(dǎo)屬性 (computed properties)。
6. 對(duì)模塊友好:可以通過(guò) NPM、Bower 或 Duo 安裝,不強(qiáng)迫你所有的代碼都遵循 Angular 的各種規(guī)定,使用場(chǎng)景更加靈活。
缺點(diǎn):
1. 新生兒:Vue.js是一個(gè)新的項(xiàng)目,沒有angular那么成熟。
2. 影響度不是很大:google了一下,有關(guān)于Vue.js多樣性或者說(shuō)豐富性少于其他一些有名的庫(kù)。
3. 不支持IE8
Angular:
Angular是一款優(yōu)秀的前端JS框架,已經(jīng)被用于Google的多款產(chǎn)品當(dāng)中。
它有以下的特性:
1.良好的應(yīng)用程序結(jié)構(gòu)
2.雙向數(shù)據(jù)綁定
3.指令
4.HTML模板
5.可嵌入、注入和測(cè)試
優(yōu)點(diǎn):
1. 模板功能強(qiáng)大豐富,自帶了極其豐富的angular指令。
2. 是一個(gè)比較完善的前端框架,包含服務(wù),模板,數(shù)據(jù)雙向綁定,模塊化,路由,過(guò)濾器,依賴注入等所有功能;3. 自定義指令,自定義指令后可以在項(xiàng)目中多次使用。
4. ng模塊化比較大膽的引入了Java的一些東西(依賴注入),能夠很容易的寫出可復(fù)用的代碼,對(duì)于敏捷開發(fā)的團(tuán)隊(duì)來(lái)說(shuō)非常有幫助。
5. angularjs是互聯(lián)網(wǎng)巨人谷歌開發(fā),這也意味著他有一個(gè)堅(jiān)實(shí)的基礎(chǔ)和社區(qū)支持。
缺點(diǎn):
1. angular 入門很容易 但深入后概念很多, 學(xué)習(xí)中較難理解.
2. 文檔例子非常少, 官方的文檔基本只寫了api, 一個(gè)例子都沒有, 很多時(shí)候具體怎么用都是google來(lái)的, 或直接問misko,angular的作者.
3. 對(duì)IE6/7 兼容不算特別好, 就是可以用jQuery自己手寫代碼解決一些.
4. 指令的應(yīng)用的最佳實(shí)踐教程少, angular其實(shí)很靈活, 如果不看一些作者的使用原則,很容易寫出 四不像的代碼, 例如js中還是像jQuery的思想有很多dom操作.
5. DI 依賴注入 如果代碼壓縮需要顯示聲明.
上面就是關(guān)于web前端三大主流框架的介紹,你更喜歡那個(gè)?
前端的業(yè)務(wù)邏輯和入門相對(duì)于后端來(lái)說(shuō)比較簡(jiǎn)單,對(duì)于無(wú)代碼基礎(chǔ)的學(xué)員來(lái)說(shuō)入門更容易。不管你是想轉(zhuǎn)行還是想通過(guò)自己的努力拿到高薪, 前端移動(dòng)與開發(fā)都是非常好的選擇。針對(duì)學(xué)員的基礎(chǔ)情況,我們會(huì)將學(xué)員分為基礎(chǔ)班和就業(yè)班兩種班型學(xué)習(xí)。如果學(xué)員零基礎(chǔ)或者基礎(chǔ)較差可以 選擇基礎(chǔ)班培訓(xùn),以便順利進(jìn)入到就業(yè)班學(xué)習(xí),如果學(xué)員有足夠的基礎(chǔ)知識(shí)我們會(huì)直接推薦進(jìn)入到就業(yè)班學(xué)習(xí)。