摘要:關(guān)于和,其實(shí)單純問兩者的區(qū)別,大家都知道,一個(gè)是開發(fā)依賴,一個(gè)是線上依賴。因?yàn)橐婚_始的開發(fā)不規(guī)范,導(dǎo)致我隨意亂裝。。一個(gè)包可以再大點(diǎn)。腳手架已經(jīng)實(shí)現(xiàn)了三分之一,現(xiàn)在是直接來作為腳手架,到最后效果應(yīng)該是的形式,不過命令內(nèi)容已經(jīng)實(shí)現(xiàn)和。
前言:最近天天加班做新項(xiàng)目,Taro版的小程序,還要實(shí)現(xiàn)富文本加海報(bào),踩了不少坑,下次專門開個(gè)坑說一下。 回到腳手架,說實(shí)話從頭寫一個(gè),即便是參考create-react-app,還是遇到了很多很多問題,這些都是需要自己親自寫過,才能有所體會(huì)。
這次會(huì)寫的有雜亂一點(diǎn),就說說自己遇到的哪些問題。雖然還沒有全部完工,但是已經(jīng)能夠基本使用,最下面會(huì)貼git地址
問題一 現(xiàn)在基本實(shí)現(xiàn)了兩個(gè)命令,start和build,start就是啟動(dòng)webpack-dev-server,這是開發(fā)環(huán)境, build就是構(gòu)建,是production環(huán)境。 不管什么命令都需要依賴 NODE_ENV=development或者production,這樣會(huì)導(dǎo)致每次npm run 的時(shí)候都要加上NODE_ENV,而且這個(gè)還不能直接寫在script命令里面,因?yàn)閣indow是不支持,需要安裝第三方庫(kù)。最后參考create-react-app
直接賦值,簡(jiǎn)單粗暴。 一開始沒想到可以這么簡(jiǎn)單粗暴,走了歪路,想要通過DefinePlugin來實(shí)現(xiàn)賦值,但其實(shí)這反倒是錯(cuò)誤的路線。需要理解編譯工具所依賴的NODE_ENV和業(yè)務(wù)代碼里面的NODE_ENV是不同的,DefinePlugin其實(shí)就是個(gè)簡(jiǎn)單的全局變量替換,只能替換chunk里面的。
問題二 優(yōu)化createWebpack,一開始的做法極為簡(jiǎn)單,直接export一個(gè)對(duì)象,導(dǎo)致靈活性很差,后來改成導(dǎo)出一個(gè)方法,接收各種配置參數(shù),返回一個(gè)webpackConfig。
問題三 webpack-dev-serve,這個(gè)問題搗鼓了很久很久。關(guān)于webpack-dev-serve的contentBase配置。一開始我設(shè)置的是dist目錄,也就是打包后的目錄,即output設(shè)置的path。因?yàn)橐郧岸际沁@樣玩的,但是這樣意味著服務(wù)依賴了一個(gè)打包構(gòu)建后的目錄dist,否則沒有辦法找到index.html。這樣就很詭異,難道第一次start都必須先build一下嗎?很不合理,而且build的時(shí)候NODE_ENV必須是development,否則js的引用地址就成了線上地址。而根據(jù)上面一個(gè)問題,簡(jiǎn)單粗暴在代碼里面寫死NODE_ENV就很難改變環(huán)境變量了,build出來的只能是線上。
看了很久的create-react-app的源碼,因?yàn)檫@個(gè)腳手架并不需要先build,一開始以為他在start的時(shí)候做了什么特殊處理,后來才發(fā)現(xiàn)壓根不是,它的webpack-dev-server配置的cotentbase竟然不是dist,而是原始目錄src/index.html。。。
這樣我很震驚啊,因?yàn)槲蚁氲氖?,js什么的,css什么的引入都必須是在webpack build之后才知道的,因?yàn)闀?huì)做拆分剝離的處理,JS的文件個(gè)數(shù)和名字不確定,如果引入的是原始目錄,那么到底是在哪兒做的JS和CSS插入操作呢,為此尋遍了源碼,一個(gè)個(gè)去找plugin,但最后發(fā)現(xiàn)其實(shí)壓根很簡(jiǎn)單。
在于html-webpack-plugin,貌似它會(huì)先在內(nèi)存中生成一份html,想要訪問內(nèi)存地址直接就是
localhost:3000,而webpack-dev-server應(yīng)該是優(yōu)先去取內(nèi)存中的index.html,沒取到就會(huì)去cotentbase中找,也就是說和cotentbase壓根沒有半毛錢關(guān)系。
產(chǎn)生錯(cuò)覺的原因在于,內(nèi)存中沒找到,而cotentbase中同樣沒找到,就會(huì)報(bào)404。至于為嘛沒有取到內(nèi)存中的值,在于我閑的沒事,設(shè)置了publicPath,為/assets/這樣導(dǎo)致,想要訪問html的地址就變成了localhost:3000/assets/index.html。其實(shí)開發(fā)環(huán)境壓根沒必要設(shè)置assets,沒半毛錢作用。
問題四 這個(gè)就是很蠢的一個(gè)問題了,很粗心。關(guān)于dependencies和devDependencies,其實(shí)單純問兩者的區(qū)別,大家都知道,一個(gè)是開發(fā)依賴,一個(gè)是線上依賴。但是我們實(shí)際開發(fā)中,不管是你開發(fā)依賴還是線上依賴,其實(shí)所有的包都會(huì)安裝,所以有的時(shí)候裝錯(cuò)地方,也沒啥的。but。。。如果你開發(fā)的是第三方包,這個(gè)問題就大了。。。如果是第三方包,只會(huì)安裝第三方包的dependencies。因?yàn)橐婚_始的開發(fā)不規(guī)范,導(dǎo)致我隨意亂裝。。結(jié)果查了半天,一直報(bào)XXX包找不到。。搗鼓了很久,才發(fā)現(xiàn)是個(gè)這么簡(jiǎn)單的問題。
問題五 關(guān)于npm publishi的時(shí)候如果報(bào)權(quán)限或者什么其他問題的錯(cuò),十有八九是 設(shè)定了源的路徑,如果是淘寶源或者公司源,需要切換回npm默認(rèn)源,才可以發(fā)布。
問題暫時(shí)就想到這么多了。其實(shí)腳手架最簡(jiǎn)單的反而是webpack配置了,這些東西一搜索網(wǎng)上一大把,配置消息我就不多說了。說幾個(gè)值得注意的地方。。第一就是splitChunks,這個(gè)設(shè)置拆包大小的時(shí)候記得注意單位,30000這個(gè)是30kb。所以我寫的是100000,意味著要拆成獨(dú)立的包,壓縮前必須有100KB,其實(shí)還可以設(shè)置大一點(diǎn),你想想100KB壓縮后估計(jì)就50,再來個(gè)GZIP就是20KB左右了。一個(gè)包可以再大點(diǎn)。
但如果是http2,也可以不用拆太大,畢竟多路復(fù)用嗎。 第二就是關(guān)于靜態(tài)資源引用的問題,其實(shí)我覺得本地業(yè)務(wù)代碼里面完全不用引入靜態(tài)資源,通通丟到云服務(wù)器就好,比如靜態(tài)圖片,我都是通通扔到七牛服務(wù)器,代碼里面直接寫死,爽歪歪,還能享受CDN加成和http2.
react+router+redux
說的有點(diǎn)亂,想到啥寫啥。主要是事件間隔有點(diǎn)久了,最近加班太忙。
腳手架已經(jīng)實(shí)現(xiàn)了三分之一,現(xiàn)在是直接clone git來作為腳手架,到最后效果應(yīng)該是npx的形式,不過命令內(nèi)容已經(jīng)實(shí)現(xiàn) easy-react start和 easy-react build。
代碼已經(jīng)更新到git了,方便給個(gè)star。 easy-react即命令的實(shí)現(xiàn)源碼還沒扔上去,等后續(xù)完工了再扔上去。畢竟還有服務(wù)器端的部分沒實(shí)現(xiàn)。
腳手架工具很多,我覺得有時(shí)間還是自己維護(hù)一份的好,想咋玩就咋玩,想升級(jí)就升級(jí),自己定制。
git init
git clone https://github.com/417673259/...
npm install
npm run start
有問題就留言,必定回復(fù),給個(gè)贊唄
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/104065.html
摘要:根據(jù)配置經(jīng)驗(yàn),還需要配置一個(gè),根據(jù)我實(shí)際的測(cè)試結(jié)果,不用手動(dòng)加入這個(gè)也可以實(shí)現(xiàn)熱更新。我們公司的腳手架沒用這個(gè)結(jié)果,導(dǎo)致自己額外增添了很多配置。,走到這里,我們會(huì)發(fā)現(xiàn)只實(shí)現(xiàn)了第一步頁面自動(dòng)刷新。很細(xì),很有意思從零開始開發(fā)一個(gè)腳手架五 這一篇可能主要講的是熱更新,寫的很細(xì),遇到很多有意思的地方,一一和大家講解下。 前沿:webpack-dev-server支持熱更新,簡(jiǎn)單的說就是你修改...
摘要:只有動(dòng)手,你才能真的理解作者的構(gòu)思的巧妙只有動(dòng)手,你才能真正掌握一門技術(shù)持續(xù)更新中項(xiàng)目地址求求求源碼系列跟一起學(xué)如何寫函數(shù)庫(kù)中高級(jí)前端面試手寫代碼無敵秘籍如何用不到行代碼寫一款屬于自己的類庫(kù)原理講解實(shí)現(xiàn)一個(gè)對(duì)象遵循規(guī)范實(shí)戰(zhàn)手摸手,帶你用擼 Do it yourself!!! 只有動(dòng)手,你才能真的理解作者的構(gòu)思的巧妙 只有動(dòng)手,你才能真正掌握一門技術(shù) 持續(xù)更新中…… 項(xiàng)目地址 https...
摘要:弄清之后,就去腳手架源代碼里面找。這樣更加靈活,而且復(fù)用性高,起新項(xiàng)目,如果差別不大,幾乎可以做到零配置,這樣開發(fā)者壓根就不需要關(guān)心業(yè)務(wù)之外的東西從零開始開發(fā)一個(gè)腳手架三 上一篇已經(jīng)初步整了個(gè)kkk-react,這一篇不寫代碼,粗略講解下create-react-app的部分源碼。 前沿:科普下看源碼的思路。以本人看過N多源碼的經(jīng)驗(yàn)總結(jié),想要看這種腳手架或者npm包的源碼,第一步就是看...
摘要:第一步創(chuàng)建兩個(gè)項(xiàng)目這個(gè)是腳手架項(xiàng)目,腳手架說白點(diǎn)就是項(xiàng)目了,但要時(shí)時(shí)看效果,總不能一直到,所以需要。但因?yàn)槭情_發(fā)腳手架啊,這一步可以放到最后來弄,先把打包構(gòu)建的步驟弄好。 前沿: 腳手架工具一大堆,但如果全部用第三方的腳手架,項(xiàng)目做起來肯定束手束腳,想來點(diǎn)差異化的東西都很難,所以最好是整一份自己的腳手架工具,想咋玩咋玩。閱讀了next腳手架和create-react-app腳手架源碼,...
摘要:前面兩篇文都只是鋪墊,今天至少要實(shí)現(xiàn)一個(gè)簡(jiǎn)單的開始之前再說一下墊片和。我一開始以為會(huì)在引入,但并不是。這是我的,當(dāng)然以后會(huì)拆出來,作為目錄下的一個(gè)執(zhí)行文件。里面就配置了一個(gè)。下一篇從零開始開發(fā)一個(gè)腳手架四 前面兩篇文都只是鋪墊,今天至少要實(shí)現(xiàn)一個(gè)簡(jiǎn)單react的hello word 開始之前再說一下墊片和presets。 前幾天突發(fā)疑問,create-react-app是怎么做的墊片,...
閱讀 3372·2021-11-04 16:10
閱讀 3871·2021-09-29 09:43
閱讀 2707·2021-09-24 10:24
閱讀 3371·2021-09-01 10:46
閱讀 2519·2019-08-30 15:54
閱讀 602·2019-08-30 13:19
閱讀 3245·2019-08-29 17:19
閱讀 1066·2019-08-29 16:40