博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
create-react-app修改为多页面支持
阅读量:6387 次
发布时间:2019-06-23

本文共 3195 字,大约阅读时间需要 10 分钟。

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

修改dev流程

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

  • yarn add globby 用于查看html文件

  • 修改config/paths.js

//遍历public下目录下的html文件生成arryconst globby = require('globby');const htmlArray = globby.sync([path.join(resolveApp('public'), '/*.html')]);//module.exports 里面增加htmlArray复制代码
  • 修改config/webpack.config.dev.js
// 遍历htmlconst entryObj = {};const htmlPluginsAray = paths.htmlArray.map((v)=> { const fileParse = path.parse(v); entryObj[fileParse.name] = [ require.resolve('./polyfills'), require.resolve('react-dev-utils/webpackHotDevClient'), `${paths.appSrc}/${fileParse.name}.js`,, ] return new HtmlWebpackPlugin({ inject: true, chunks:[fileParse.name], template: `${paths.appPublic}/${fileParse.base}`, filename: fileParse.base })});
entry:entryObj
// new HtmlWebpackPlugin({// inject: true,// chunks: ["index"],// template: paths.appPublic + '/index.html',// }),...htmlPluginsAray,复制代码
  • 修改config/webpackDevServer.config.js
// 增加const path = require('path');const htmlPluginsAray = paths.htmlArray.map((v)=> {  const fileParse = path.parse(v);  return {    from: new RegExp(`^\/${fileParse.base}`), to: `/build/${fileParse.base}`  };});
rewrites: htmlPluginsAray复制代码

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

修改product流程

  • 修改config/
//增加// 遍历htmlconst entryObj = {};const htmlPluginsAray = paths.htmlArray.map((v)=> {  const fileParse = path.parse(v);    entryObj[fileParse.name] = [    require.resolve('./polyfills'),    `${paths.appSrc}/${fileParse.name}.js`,  ];  console.log(v);  return new HtmlWebpackPlugin({    inject: true,    chunks:[fileParse.name],    template: `${paths.appPublic}/${fileParse.base}`,    filename: fileParse.base  })});
entry: entryObj,
...htmlPluginsAray,复制代码
  • 增加复制模块(yarn add cpy
  • 修改scripts/build.js
// function copyPublicFolder () 替换// 原来的方法是复制public下所有的内容,因为增加了多html 所以不再直接复制过去(直接复制会覆盖html)const copyPublicFolder = async() => {  await cpy([`${paths.appPublic}/*.*`, `!${paths.appPublic}/*.html`], paths.appBuild);  console.log('copy success!');  // fs.copySync(paths.appPublic, paths.appBuild, {  //   dereference: true,  //   filter: file => file !== paths.appHtml,  // });}复制代码

以上修改后测试下yarn build 查看下html对应生成对不对,正常是OK的。

增加功能

  • sass支持(此参考create-react-app的文档,注意不要直接复制文档里面的"start": "react-scripts start", "build": "react-scripts build",因为我们前面已经yarn eject,所以这样用的话是有问题的可以自行体验一下)
// 增加模块yarn add node-sass-chokidar npm-run-all// package.json删除配置"start": "node scripts/start.js","build": "node scripts/build.js",// package.json里面增加scripts"build-css": "node-sass-chokidar src/scss -o src/css","watch-css": "npm run build-css && node-sass-chokidar src/scss -o src/css --watch --recursive","start-js": "node scripts/start.js","start": "npm-run-all -p watch-css start-js","build-js": "node scripts/build.js","build": "npm-run-all build-css build-js",复制代码
  • html引入模块
yarn add html-loader
<%= require('html-loader!./partials/header.html') %>复制代码
  • html里可以写img支持打包到build,如果不写的话是无法打包的,除非你在js里面require
复制代码

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

转载于:https://juejin.im/post/5afcd2bd51882542c832f155

你可能感兴趣的文章
我的友情链接
查看>>
开机启动流程
查看>>
微信小程序把玩(十一)icon组件
查看>>
在symfony2项目中100%提升doctrine的性能
查看>>
python whl是什么文件
查看>>
什么是NIO
查看>>
记一次数据库事务的并发同步控制
查看>>
通过公历年计算天干地支
查看>>
文件写入
查看>>
ftp
查看>>
心智圖軟體戰國時代
查看>>
python元字典
查看>>
希尔排序法对一维数组排序
查看>>
vim正则表达式
查看>>
Windows2008/2012多用户同时远程连接终端服务授权
查看>>
查看mysql编译参数
查看>>
MySQL数据表基本操作
查看>>
LM_Sensors on Cent OS 5.4 How To Get And Install The Coretemp Module
查看>>
ubuntud——系统备份和恢复
查看>>
Oracle对数据的导出和导入,建立用户,删除用户以及其下的所有表
查看>>