摘要:修改為多入口編譯參考了這篇文章需求和出發(fā)點我們會有較多的小的單頁應(yīng)用,主要是一些簡單的頁面和活動之類。甚至輸入顯然不存在的,也顯示為的內(nèi)容。
create-react-app 修改為多入口編譯
date: 2018.07.31
參考了這篇文章
需求和出發(fā)點我們會有較多的小的單頁應(yīng)用,主要是一些簡單的頁面和活動之類。這些頁面相互之間沒有交集,但是會有一些可以共用的代碼,資源、接口、組件啥的。
對此,我們想到了兩種解決方案:
react-router 路由方案;
同一個項目的多入口編譯;
針對我們的業(yè)務(wù)需求,其實 react-router 方案會有兩個小問題:
單個活動的修改,其實需要編譯整個項目;
若是不做編譯優(yōu)化,整個項目的包會比較大,但其實沒必要,當(dāng)然這個可以通過 react-router 的按需加載來解決;
權(quán)衡之下,我們還是選擇了第二個方案——改造項目成為多入口編譯。
文件結(jié)構(gòu)設(shè)計改進后,整個項目的結(jié)構(gòu)大體如下:
- project - build - config - public - scripts - src - api - component - site - site1 - index.html - index.js - ... - site2 - index.html - index.js - ... - package.json
site 文件夾下的所有文件夾都是一個獨立的項目,項目通用的代碼、資源被抽離到更外層的文件夾內(nèi),如 api、component 等,文件夾內(nèi)都會有自己的 index.html 和 index.js,這會作為該項目的 html 模板和入口文件。下面,我們看下是如何修改編譯過程的。
修改入口和出口編譯需要指定編譯的入口和輸出的位置,在 create-react-app 本來生成的 code 中,只有單入口和單出口,但是其實 webpack 是支持多入口、多出口的。
入口修改create-react-app 命令生成的 config 文件夾中,有個 paths.js 文件,這里面 export 了比較常用的路徑。在這里,我對 src/site 文件夾內(nèi)的文件夾進行了遍歷,生成為對象。具體代碼如下:
// all site paths function allSitePath(source) { const { lstatSync, readdirSync } = fs const { join } = path const result = {} const isDirectory = source => lstatSync(source).isDirectory() readdirSync(source).map(name => { let path = join(resolveApp(source), name) if (isDirectory(path)) result[name] = path }) return result } module.exports = { ... allSites: allSitePath("src/site"), }
在 webpack.config.dev.js / webpack.config.prod.js 中找到 module.exports 的 entry 屬性,將其修改為:
// 動態(tài)生成 entry const entry = {} Object.keys(paths.allSites).forEach(item => { entry[item] = [ require.resolve("./polyfills"), require.resolve("react-dev-utils/webpackHotDevClient"), require.resolve("react-error-overlay"), paths.allSites[item] ] }) module.exports = { ... entry: entry, ... }出口修改
出口的修改分為兩部分,一部分是 module.exports 的 output,添加 name 以使靜態(tài)資源區(qū)分不同項目:
module.exports = { ... output: { path: paths.appBuild, pathinfo: true, filename: "static/js/[name].bundle.js", chunkFilename: "static/js/[name].chunk.js", publicPath: publicPath, devtoolModuleFilenameTemplate: info => path.resolve(info.absoluteResourcePath).replace(//g, "/"), }, ... }
另一部分是 plugin 的修改,webpack 中,每個 HTML 文件的輸出,其實是一個 HtmlWebpackPlugin,我們需要添加多個 HtmlWebpackPlugin,以求生成多個 HTML:
// 動態(tài)生成 plugins const plugins = [] Object.keys(paths.allSites).forEach(item => { plugins.push(new HtmlWebpackPlugin({ inject: true, chunks: [item], template: `${paths.allSites[item]}/index.html`, filename: `${item}/index.html`, })) }) module.exports = { ... plugins: [ ... ].concat(plugins), ... }修改 webpack Dev Server 配置
上述配置做完后,理論就可以打包出多入口的版本;但使用npm start啟動后,發(fā)現(xiàn)無論輸入/index.html還是/admin.html,好像都是和原來/index.html顯示一樣的內(nèi)容。甚至輸入顯然不存在的/xxxx.html,也顯示為/index.html的內(nèi)容。
這里,我們還需要修改 /config/webpackDevServer.config.js,做一些額外配置。
const rewrites = [] Object.keys(paths.allSites).forEach(item => { rewrites.push({ from: new RegExp(`^/${item}/`, "i"), to: `/${item}/index.html`, }) }) ... module.exports = function(proxy, allowedHost) { return { ... historyApiFallback: { // Paths with dots should still use the history fallback. // See https://github.com/facebookincubator/create-react-app/issues/387. disableDotRule: true, // 指明哪些路徑映射到哪個html rewrites: rewrites, }, ... }; };
OK,到這里,整個改造就完成了。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96471.html
摘要:如果不配置,則將所有的文件都注入。指明生成的路徑,如果不配置就是。配置了新的,避免與第一個入口相互覆蓋。甚至輸入顯然不存在的,也顯示為的內(nèi)容。這種現(xiàn)象,初步判斷是服務(wù)器把所有請求重定向到了。至此,環(huán)境的多入口問題就解決了。前端根據(jù)自行配置。 背景 還是之前的那個項目,做完國際化沒多久,還沒來得及劃水, 又有新的活了 -- 移動端的兼容。 考慮到后期的復(fù)雜度, 需要做兩套資源。 具體的目...
摘要:如果不配置,則將所有的文件都注入。指明生成的路徑,如果不配置就是。配置了新的,避免與第一個入口相互覆蓋。甚至輸入顯然不存在的,也顯示為的內(nèi)容。這種現(xiàn)象,初步判斷是服務(wù)器把所有請求重定向到了。至此,環(huán)境的多入口問題就解決了。前端根據(jù)自行配置。 背景 還是之前的那個項目,做完國際化沒多久,還沒來得及劃水, 又有新的活了 -- 移動端的兼容。 考慮到后期的復(fù)雜度, 需要做兩套資源。 具體的目...
摘要:暴露所有內(nèi)建配置,項目下會新增或?qū)Σ糠峙渲梦募M行修改。開發(fā)環(huán)境開發(fā)時,前端項目和后端項目運行時端口端口不同,存在跨域問題。項目目錄結(jié)構(gòu)優(yōu)化項目目錄結(jié)構(gòu)優(yōu)化開發(fā)目錄主要是目錄,因此需要修改的目錄主要是目錄。 1 開發(fā)環(huán)境準備(windows) 1.1 安裝nodejs和npm 1) 下載nodejs安裝包:http://nodejs.org/en/download/ nodejs安...
摘要:相信用的同學(xué)也不少找到函數(shù)在其中中添加啟用編譯。。。react 最近已經(jīng)開始使用react技術(shù)棧了,從頭開始搭建項目,有必要的記錄一下配置的過程以及項目分層的思路,這次后臺項目采用的主要采用react-create-app腳手架以及Ant DesignUI 以及多語言react-intl create-react-app 這是官方維護的腳手架應(yīng)用 我們一般也采用這個 $ npm or c...
react 最近已經(jīng)開始使用react技術(shù)棧了,從頭開始搭建項目,有必要的記錄一下配置的過程以及項目分層的思路,這次后臺項目采用的主要采用react-create-app腳手架以及Ant DesignUI 以及多語言react-intl create-react-app 這是官方維護的腳手架應(yīng)用 我們一般也采用這個 $ npm or cnpm $ npm install create-react...
閱讀 2615·2021-11-22 15:25
閱讀 1444·2021-11-15 17:59
閱讀 1146·2021-09-29 09:34
閱讀 1555·2021-09-26 09:46
閱讀 3038·2021-09-02 15:40
閱讀 1197·2019-08-30 15:56
閱讀 3290·2019-08-30 15:55
閱讀 701·2019-08-29 17:08