摘要:將它開源出來,希望能給某些同學(xué)帶來幫助,如果有設(shè)計(jì)的不好的地方,也希望能及時(shí)指出,共同進(jìn)步。和為組件,下的文件一般為直接配合路由使用的包裝組件,為具體業(yè)務(wù)組件,這個地方有的規(guī)范將組件分為三層,我個人認(rèn)為這個必要性不大。
個人學(xué)習(xí)使用react已經(jīng)有一段時(shí)間了,雖然沒有在真正的產(chǎn)品項(xiàng)目中大規(guī)模使用react,但是在自己的博客、小網(wǎng)站、一些開源項(xiàng)目中已經(jīng)使用過好幾次了,使用react創(chuàng)建項(xiàng)目個人也有了一些心得并且經(jīng)過嘗試驗(yàn)證,總結(jié)了這個可以用于起步的框架模版react-redux-tpl。
將它開源出來,希望能給某些同學(xué)帶來幫助,如果有設(shè)計(jì)的不好的地方,也希望能及時(shí)指出,共同進(jìn)步。
宏觀解讀在現(xiàn)在,我們其實(shí)有很多腳手架可以使用,例如create-react-app就是業(yè)界比較優(yōu)秀的應(yīng)用開發(fā)工具之一,筆者也使用過,但是我的感覺是由于它已經(jīng)將所有的工具集成好了,可控性反而不那么強(qiáng),有些內(nèi)容也不一定會了解的很透徹,但是自己從0開始配置呢,又會比較麻煩,每次從新開一個項(xiàng)目又需要做很多前置工作,比較麻煩。
react-redux-tpl這個模版就是為了解決這個問題,它基于Express,集成了ES6、react、redux(以及redux-dev-tool)、react-router、webpack熱更新,并且按照一定的規(guī)則和最佳實(shí)踐進(jìn)行文件組織和代碼組織,可以使開發(fā)人員幾乎無需寫一行配置代碼就可以直接開發(fā)業(yè)務(wù)。
現(xiàn)在它的使用方式是這樣的:
npm install react-redux-tpl -g react-redux-tpl FileName cd FileName npm install npm run start
之后再chrome中打開localhost:7777即可看到效果(注:如果網(wǎng)速較慢,特別是在使用教育網(wǎng)的情況下,執(zhí)行第二個命令之后可能要稍微等幾分鐘)。
或者你也可以直接git clone https://github.com/aircloud/react-redux-tpl將整個模版項(xiàng)目下載下來,到這個文件夾里:
npm install npm run start
同樣可以達(dá)到效果
文件組織我認(rèn)為,一個一百個文件以上的項(xiàng)目,最重要的事情就是文件組織,文件組織對開發(fā)效率、維護(hù)效率、多人協(xié)作甚至代碼重用,都有很重要的意義,而現(xiàn)在隨著組件化開發(fā)的流行和更精確的粒度控制,我們的文件很容易變得非常多。
我在文件組織方式是這樣的,這里面主要列出重點(diǎn)目錄并著重突出一下前端文件:
-bin -common //react核心文件目錄 |- actions |- components |- Common |- HomePage |- SubPage ...... |- containers |- enter |- reducers |- routes |- store |- Utils -controller -public //靜態(tài)資源目錄 |- images |- javascripts index.html -routes -views app.js webpack.config.js ......
這里面首先說一下目錄命名規(guī)則,目錄出了最末端只有jsx的文件目錄采用大駝峰命名規(guī)則,并且和里面的首要jsx文件同名之外,一律采用小寫,并且盡量控制不出現(xiàn)復(fù)合單詞。
react核心文件目錄之所以命名common,是因?yàn)榭紤]到如果使用服務(wù)端渲染,這便相當(dāng)于一個公共資源目錄,服務(wù)端渲染我們可以考慮在routes目錄下的路由層進(jìn)行配置(該模版框架沒有采用服務(wù)端渲染,需要自行配置,但比較簡單)。
common下的actions、reducers、store都是和redux有關(guān)的文件目錄,enter為入口目錄,enter目錄下的文件通常為webpack配置時(shí)候的入口文件。
containers和components為組件,containers下的文件一般為直接配合路由使用的包裝組件,components為具體業(yè)務(wù)組件,這個地方有的規(guī)范將組件分為三層,我個人認(rèn)為這個必要性不大。
另外,除了一些公共樣式需要放在公共文件,我建議每一個組件搭配一個同名樣式文件:
-HomePage.js -HomePage.less
這樣控制起來會比較方便,另外我們可以嘗試采用css-modules,個人認(rèn)為雖然解決了class沖突問題,但是卻不利于代碼調(diào)試,而且也有一定遷移成本,故不用。
Webpack配置關(guān)于webpack配置優(yōu)化的問題,網(wǎng)上的教程和博客都非常的多,我在react-redux-tpl進(jìn)行了一部分優(yōu)化配置,并且利用了express的插件進(jìn)行了熱更新的配置。考慮到模版框架的通用和簡潔性,并且考慮到編譯速度優(yōu)化的選擇多樣性,我在這里簡化了配置。
如果對編譯時(shí)間要求比較高的話,僅僅做這些是不管用的,我們應(yīng)當(dāng)進(jìn)行更多的性能優(yōu)化。關(guān)于webpack性能調(diào)優(yōu),我在這里總結(jié)了一些內(nèi)容,可以進(jìn)行嘗試。
另外這里面值得一提的是使用的webpack-hash-sync這個插件,關(guān)于引用的js文件名同步的問題,雖然已經(jīng)有html-webpack-plugin這個插件,但是我認(rèn)為它是不符合我的編程習(xí)慣的,它是通過我們的配置,直接生成html文件,而實(shí)際上我們的html文件都是通常先寫好,并且做很多個性化配置內(nèi)容,方便又簡潔,直接使用html-webpack-plugin很多時(shí)候是無法做到的。
而使用webpack-hash-sync我們可以給定正則表達(dá)式,每次webpack的時(shí)候都會一個一個的去匹配正則表達(dá)式并且把hash值或者chunkhash進(jìn)行改變:
new WebpackHashSync({ file:["output.*?js","common.*?js"], path:path.join(__dirname, "public/"), html:["index.html"], hash:true, chunkhash:false }),使用redux
項(xiàng)目中引入了redux-devtools這個調(diào)試功能插件(可關(guān)閉,最簡單的辦法就是不在common/enter/index.js中引入了),并且默認(rèn)引入redux-thunk和react-router-redux這兩個中間件,前者是可以直接在action中發(fā)異步請求,后者是可以增強(qiáng)一些react-router的功能。
我建議大家可以看看他們的GitHub主頁,講的都挺不錯的,特別是前者,十來行代碼的一個插件,近5000個star,不得不說,是牛逼。
在common/actions/index.action.js里,我寫了一些示例的同步的和異步的action,大家可以參考這個寫法,直接上手。
另外,我關(guān)于一個redux的使用原則是:
只有被共享數(shù)據(jù)才會被用在redux中,組件的非共享數(shù)據(jù)(比如一些展示列表),不要放在redux中,而是隨著組件生命周期被請求、構(gòu)造、消失...
react組件寫react的項(xiàng)目,最重要最耗時(shí)的,還是react組件開發(fā),我關(guān)于組件粒度劃分的幾個原則如下(當(dāng)然這在這個模版框架中可能沒有體現(xiàn)出來):
如果列表中的元素存在動態(tài)交互,便盡可能地將元素做成一個獨(dú)立的組件。
為了提高效率和保持整站用戶體驗(yàn)的統(tǒng)一,我們盡可能復(fù)用低級組件,比如定制的按鈕、列表、標(biāo)簽等,并且都統(tǒng)一放在Common文件夾下。
在react組件開發(fā)中,我一般是給每一個模塊(或者一個頁面)一個文件夾,比如HomePage,這個文件夾下只有HomePage.js是需要被別的目錄下文件引入的,而HomePage需要的一些公共組件在Common目錄下,私有組件在HomePage本文件目錄下。
另外,我們可以在HomePage.js中利用ES7中的裝飾者模式配置react-redux:
@connect(state => { return { Info:state.rootReducer.getInfo.info }; }, { getAllClass,updateInfo }) class HomePage extends Component{ //... }
其他的子組件的數(shù)據(jù)通過props傳入(當(dāng)然,如果是子組件的私有數(shù)據(jù),還是在子組件內(nèi)自行處理)
總結(jié)以上是我梳理的關(guān)于構(gòu)建這個模版框架的一些思考,由于某些內(nèi)容還未深思熟慮,因此目前沒有寫入,我也會在接下來的一段時(shí)間內(nèi),繼續(xù)打磨這個內(nèi)容,爭取整理出一套還不錯的實(shí)踐。
如果有些許認(rèn)同,歡迎給star鼓勵。
如果有bug或者設(shè)計(jì)不好的地方,請?jiān)谶@里提出,我會在24小時(shí)之內(nèi)回復(fù)并且嘗試解決問題。
[注1]本文中提到的一些對比的例子,都是個人角度的一些片面見解和個人習(xí)慣問題,實(shí)際上我個人還是認(rèn)為這些項(xiàng)目十分優(yōu)秀的,成熟度也比較高,向前輩致敬。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/82293.html
摘要:在本次上,京東云將在大會上為對云原生感興趣的研發(fā)和運(yùn)維人員帶來利用延遲加載快速啟動容器的話題分享。今天聊的主角云原生也是一樣。 showImg(https://segmentfault.com/img/bVbtNqp?w=688&h=113); showImg(https://segmentfault.com/img/bVbtQaR?w=684&h=327); showImg(http...
摘要:在本次上,京東云將在大會上為對云原生感興趣的研發(fā)和運(yùn)維人員帶來利用延遲加載快速啟動容器的話題分享。今天聊的主角云原生也是一樣。 showImg(https://segmentfault.com/img/bVbtNqp?w=688&h=113); showImg(https://segmentfault.com/img/bVbtQaR?w=684&h=327); showImg(http...
摘要:華為開發(fā)者大賽是面向全國開發(fā)者的大型軟件競賽,活動過程對選手開放云計(jì)算大數(shù)據(jù)物聯(lián)網(wǎng)企業(yè)云通信等多個產(chǎn)品的服務(wù)和支持,旨在尋找創(chuàng)新的種子并共同孵化出創(chuàng)新的解決方案,幫助開發(fā)者實(shí)現(xiàn)業(yè)務(wù)創(chuàng)新落地。新一代信息技術(shù)正在給人類社會帶來巨大的影響,大數(shù)據(jù)、物聯(lián)網(wǎng)、云計(jì)算等技術(shù)開始進(jìn)入各個應(yīng)用行業(yè),例如共享單車、智慧物流等項(xiàng)目利用信息技術(shù)手段實(shí)現(xiàn)了更高效、更精準(zhǔn)的營銷效果。信息化趨勢帶來大眾創(chuàng)新的發(fā)展機(jī)遇,...
摘要:前端每周清單第期現(xiàn)狀分析與優(yōu)化策略單元測試爬蟲作者王下邀月熊編輯徐川前端每周清單專注前端領(lǐng)域內(nèi)容,以對外文資料的搜集為主,幫助開發(fā)者了解一周前端熱點(diǎn)分為新聞熱點(diǎn)開發(fā)教程工程實(shí)踐深度閱讀開源項(xiàng)目巔峰人生等欄目。 showImg(https://segmentfault.com/img/remote/1460000011008022); 前端每周清單第 29 期:Web 現(xiàn)狀分析與優(yōu)化策略...
閱讀 1482·2019-08-30 15:55
閱讀 1183·2019-08-30 15:52
閱讀 1303·2019-08-29 13:53
閱讀 1475·2019-08-29 11:19
閱讀 2987·2019-08-26 13:29
閱讀 539·2019-08-26 11:33
閱讀 2604·2019-08-23 17:20
閱讀 1033·2019-08-23 14:14