当前位置:Gxlcms > JavaScript > create-react-app修改为多页面支持的方法

create-react-app修改为多页面支持的方法

时间:2021-07-01 10:21:17 帮助过:54人阅读

新公司前端就我一个,目前个人选型用react作技术栈开发前端h5页面。最近做一个需求是pc页面需要seo的,后端是Java开发,又不想自己用ssr做seo渲染,只好写html给java大神改成jsp了。然而这个又需要搞一套工作流太麻烦(太懒了),所以直接拿来create-react-app的工作流进行修改了。附上Git地址。

修改dev流程

在已经通过create-react-app生成项目的基础下yarn run eject

yarn add globby 用于查看html文件

修改config/paths.js

  1. //遍历public下目录下的html文件生成arry
  2. const globby = require('globby');
  3. const htmlArray = globby.sync([path.join(resolveApp('public'), '/*.html')]);
  4. //module.exports 里面增加
  5. htmlArray

修改config/webpack.config.dev.js

  1. <!--增加配置-->
  2. // 遍历html
  3. const entryObj = {};
  4. const htmlPluginsAray = paths.htmlArray.map((v)=> {
  5. const fileParse = path.parse(v);
  6. entryObj[fileParse.name] = [
  7. require.resolve('./polyfills'),
  8. require.resolve('react-dev-utils/webpackHotDevClient'),
  9. `${paths.appSrc}/${fileParse.name}.js`,,
  10. ]
  11. return new HtmlWebpackPlugin({
  12. inject: true,
  13. chunks:[fileParse.name],
  14. template: `${paths.appPublic}/${fileParse.base}`,
  15. filename: fileParse.base
  16. })
  17. });
  18. <!--entry 替换为entryObj-->
  19. entry:entryObj
  20. <!--替换htmlplugin内容-->
  21. // new HtmlWebpackPlugin({
  22. // inject: true,
  23. // chunks: ["index"],
  24. // template: paths.appPublic + '/index.html',
  25. // }),
  26. ...htmlPluginsAray,

修改config/webpackDevServer.config.js

  1. // 增加
  2. const path = require('path');
  3. const htmlPluginsAray = paths.htmlArray.map((v)=> {
  4. const fileParse = path.parse(v);
  5. return {
  6. from: new RegExp(`^\/${fileParse.base}`), to: `/build/${fileParse.base}`
  7. };
  8. });
  9. <!--historyApiFallback 增加 rewrites-->
  10. rewrites: htmlPluginsAray

以上就是dev模式下的修改了,yarn start一下试试。

修改product流程

修改config/

  1. //增加
  2. // 遍历html
  3. const entryObj = {};
  4. const htmlPluginsAray = paths.htmlArray.map((v)=> {
  5. const fileParse = path.parse(v);
  6. entryObj[fileParse.name] = [
  7. require.resolve('./polyfills'),
  8. `${paths.appSrc}/${fileParse.name}.js`,
  9. ];
  10. console.log(v);
  11. return new HtmlWebpackPlugin({
  12. inject: true,
  13. chunks:[fileParse.name],
  14. template: `${paths.appPublic}/${fileParse.base}`,
  15. filename: fileParse.base
  16. })
  17. });
  18. <!--修改entry-->
  19. entry: entryObj,
  20. <!--替换 new HtmlWebpackPlugin 这个值-->
  21. ...htmlPluginsAray,

增加复制模块(yarn add cpy

修改scripts/build.js

  1. // function copyPublicFolder () 替换
  2. // 原来的方法是复制public下所有的内容,因为增加了多html 所以不再直接复制过去(直接复制会覆盖html)
  3. const copyPublicFolder = async() => {
  4. await cpy([`${paths.appPublic}/*.*`, `!${paths.appPublic}/*.html`], paths.appBuild);
  5. console.log('copy success!');
  6. // fs.copySync(paths.appPublic, paths.appBuild, {
  7. // dereference: true,
  8. // filter: file => file !== paths.appHtml,
  9. // });
  10. }

以上修改后测试下yarn build

查看下html对应生成对不对,正常是OK的。

增加功能

sass支持(此参考create-react-app的文档,注意不要直接复制文档里面的"start": "react-scripts start", "build": "react-scripts build",因为我们前面已经yarn eject,所以这样用的话是有问题的可以自行体验一下)

  1. // 增加模块
  2. yarn add node-sass-chokidar npm-run-all
  3. // package.json删除配置
  4. "start": "node scripts/start.js",
  5. "build": "node scripts/build.js",
  6. // package.json里面增加scripts
  7. "build-css": "node-sass-chokidar src/scss -o src/css",
  8. "watch-css": "npm run build-css && node-sass-chokidar src/scss -o src/css --watch --recursive",
  9. "start-js": "node scripts/start.js",
  10. "start": "npm-run-all -p watch-css start-js",
  11. "build-js": "node scripts/build.js",
  12. "build": "npm-run-all build-css build-js",

html引入模块

  1. yarn add html-loader
  2. <!--index.html-->
  3. <%= require('html-loader!./partials/header.html') %>

html里可以写img支持打包到build,如果不写的话是无法打包的,除非你在js里面require

  1. <img src="<%= require('../src/imgs/phone.png') %>" alt="">

后面还要取消hash之类的配置,这个就不记录了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

人气教程排行