摘要:在引起狀態(tài)變化的時刻,框架自動觸發(fā)臟檢查,也可以手動執(zhí)行臟檢查,直接操作更新視圖。最后,說了這么多,大家在具體選型時還是要首先分析自己的需求和現(xiàn)狀,然后再做選擇。
作為一個軟件開發(fā)者,最大的挑戰(zhàn)就是在不斷涌現(xiàn)的新技術(shù)中進行取舍,持續(xù)學習是從事這一行業(yè)的必備技能。在這個領(lǐng)域里,技術(shù)更新最快地又非前端莫屬了。各種框架的出現(xiàn)、版本的更新此起彼伏,呈現(xiàn)出一派欣欣向榮之景。
在項目中必不可少的便是前端,它是系統(tǒng)的門面、是用戶對系統(tǒng)最直接的體驗,顏值高低也是決定系統(tǒng)好壞的關(guān)鍵,那么作為一名軟件開發(fā)攻城獅,怎么能放棄這片藍海呢?沒準了解了解前端的世界,就能多一項技能、升職加薪、贏取白(gao)富(fu)美(shuai)、走向人生巔峰呢?
那么,在一個項目中,我們要回答的第一個問題就是“這么多的框架,該使用哪一個?”這篇文章將嘗試從項目實施相關(guān)方面入手,對目前大熱框架的特點進行分析,幫助你選擇最合適的一款。
由于篇幅有限、框架眾多,在分析之前,我們從版本更新頻度和社區(qū)活躍度來進行初步的篩選。已經(jīng)出現(xiàn)了比較久的Backbone和Knockout, 目前流行度正在持續(xù)衰退,說明市場已經(jīng)做出了選擇,市面上出現(xiàn)了更有競爭力的替代品; 還有aurelia這類的新涌現(xiàn)者,需要等待時間的檢驗。一個有活躍社區(qū)支撐,并能得到長期支持的框架無疑能給我們更大的信心。因此,Angular, Ember,Vue或者React都是理想的選擇。
那么在項目實施中,我們一般會關(guān)注哪些方面呢?
有過前端開發(fā)經(jīng)驗的同僚們可能會想到:要有可復用的組件,要控制質(zhì)量做測試和靜態(tài)檢查,要有組件隔離的樣式方便實現(xiàn)Responsive,要打包部署方便,最好學起來不要太復雜,方便能力建設(shè)、節(jié)省招聘成本等等。
接下來,我們將從組件復用、測試和學習曲線這三個主要的方面對Angular4,Ember.js,Vue.js和React這四個當前最流行的框架來做更深入的分析,提供更具體的參考。
1. 可復用的組件組件復用是每個項目都會重點關(guān)注的一個維度。合適的、職責單一的組件會大大提升新特性的開發(fā)效率和工程的可維護性,也能方便地進行測試。那么他們的表現(xiàn)都如何呢:
概括起來,就是Vue、Component的組件相對靈活、輕量,添加依賴就可以無縫集成到遺留系統(tǒng)中。對于從0到1的系統(tǒng),也可以使用新的實踐來構(gòu)建工程,例如ES6、Webpack等技術(shù)。Angular4官方推薦使用TypeScript,這需要多帶帶構(gòu)建和打包,不方便與遺留系統(tǒng)集成。Ember.js自定義了一整套生態(tài),基于CoC理念的設(shè)計,采用了前端工程中比較前沿的實踐和標準,很難與遺留系統(tǒng)集成,更適合在新項目中使用。至于數(shù)據(jù)綁定,各有優(yōu)勢。雙向綁定在表單交互多的場景中更便捷,單向綁定在管理跟蹤記錄組件狀態(tài)時更高效。組件狀態(tài)更新,各有不同的實現(xiàn):
Vue2.js通過定義setter來監(jiān)聽狀態(tài)變化,特殊場景需要特殊的API支持, 基于virtual DOM的視圖更新。
React在組件的狀態(tài)或?qū)傩缘淖兓螅彩腔趘irtual DOM的視圖更新。
Angular4在引起狀態(tài)變化的時刻,框架自動觸發(fā)臟檢查,也可以手動執(zhí)行臟檢查,直接操作HTML DOM更新視圖。
Ember.js提供數(shù)據(jù)模型,所有數(shù)據(jù)的操作通過API執(zhí)行,使用Glimmer引擎進行HTML渲染和更新。
其中,主要的區(qū)別是Angular4是通過事件監(jiān)聽,對比數(shù)據(jù)更新,直接操作DOM來更新視圖,而其它都通過Virtual DOM的思路來更新視圖。
2. 組件測試測試是提高軟件質(zhì)量的有效手段,易于編寫測試的框架,能降低編寫測試的成本,充足的測試也能提高我們交付軟件的信心。它們在組件測試方面的比較如下:
可見,Vue, React測試靈活,可以根據(jù)項目具體情況來定制,但是沒有統(tǒng)一的測試實踐規(guī)范,對開發(fā)人員的能力有較大依賴。Angular4和Ember概念多,有官方推薦的實踐,要完全掌握難度大,優(yōu)勢是實現(xiàn)起來更規(guī)范。
3. 學習曲線在技術(shù)選型過程中,保證項目按時交付,控制風險,團隊能力建設(shè)提升,都是需要考慮的因素。作為一個軟件服務(wù)公司,如何快速的提升人員能力,選用學習曲線合適的框架,控制項目成本也是一門技術(shù)活。下面,對使用這些框架的難度進行了一些簡要分析:
總結(jié)通過上面三個維度的分析,我們發(fā)現(xiàn)Vue.js和React的重點更側(cè)重于創(chuàng)建可復用、易于測試、能靈活集成的組件。當然,通過其它擴展組件,以及一些腳手架插件的支持,也可以方便的搭建一個采用最新實踐的前端應(yīng)用的構(gòu)建框架。它們最大的優(yōu)點是按需定制,學習曲線平滑,構(gòu)建出來的應(yīng)用小而精。
相對來說,Angular4和Ember是大而全的框架,它們更側(cè)重于大型前端工程的構(gòu)建,為開發(fā)人員屏蔽項目構(gòu)建底層的細節(jié),提出了自己的一套解決方案。使用它們的難點是要度過前期曲線陡峭的學習期,優(yōu)點是由于使用了標準化的開發(fā)方式,后期能極大的提高開發(fā)生產(chǎn)力,提升開發(fā)效率。
最后,說了這么多,大家在具體選型時還是要首先分析自己的需求和現(xiàn)狀,然后再做選擇。不求最酷炫,只求最合適!
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/52482.html
摘要:在引起狀態(tài)變化的時刻,框架自動觸發(fā)臟檢查,也可以手動執(zhí)行臟檢查,直接操作更新視圖。最后,說了這么多,大家在具體選型時還是要首先分析自己的需求和現(xiàn)狀,然后再做選擇。 作為一個軟件開發(fā)者,最大的挑戰(zhàn)就是在不斷涌現(xiàn)的新技術(shù)中進行取舍,持續(xù)學習是從事這一行業(yè)的必備技能。在這個領(lǐng)域里,技術(shù)更新最快地又非前端莫屬了。各種框架的出現(xiàn)、版本的更新此起彼伏,呈現(xiàn)出一派欣欣向榮之景。 在項目中必不可少的便...
摘要:在引起狀態(tài)變化的時刻,框架自動觸發(fā)臟檢查,也可以手動執(zhí)行臟檢查,直接操作更新視圖。最后,說了這么多,大家在具體選型時還是要首先分析自己的需求和現(xiàn)狀,然后再做選擇。 作為一個軟件開發(fā)者,最大的挑戰(zhàn)就是在不斷涌現(xiàn)的新技術(shù)中進行取舍,持續(xù)學習是從事這一行業(yè)的必備技能。在這個領(lǐng)域里,技術(shù)更新最快地又非前端莫屬了。各種框架的出現(xiàn)、版本的更新此起彼伏,呈現(xiàn)出一派欣欣向榮之景。 在項目中必不可少的便...
摘要:在上一篇文章基于分支,從到,再到,簡單的介紹了這里分享在開發(fā)過程中,前端選擇的心理活動。而作為核心開發(fā)之一,也負責前端這塊的開發(fā)。 在上一篇文章《 ThinkSNS+基于Laravel master分支,從1到 0,再到0.1》,簡單的介紹了 ThinkSNS+ ,這里分享在開發(fā)過程中,前端選擇的心理活動。 Laravel Mix的放棄 在 Laravel 中,前端工作流默認是由 la...
摘要:小韓坐在我的對面喃喃的說道。彬哥,我是不是錯了,如果再給我一次機會,我一定會拉住她,告訴她其實她比工作更重要。小韓,突然間對我說我覺得我生活和工作的混亂,并不是因為繁忙,而是我自己就從來沒有仔細去想還有就是對時間安排的不合理。 showImg(https://segmentfault.com/img/bV1DqS?w=3500&h=2205); 我不戴金箍,救不了她,戴了金箍,愛不了她...
閱讀 3309·2021-09-09 11:39
閱讀 1239·2021-09-09 09:33
閱讀 1139·2019-08-30 15:43
閱讀 557·2019-08-29 14:08
閱讀 1741·2019-08-26 13:49
閱讀 2390·2019-08-26 10:09
閱讀 1556·2019-08-23 17:13
閱讀 2293·2019-08-23 12:57