时间:2021-05-26
新公司前端就我一个,目前个人选型用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
//遍历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-->entry:entryObj<!--替换htmlplugin内容-->// 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}` };});<!--historyApiFallback 增加 rewrites-->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--> entry: entryObj,<!--替换 new HtmlWebpackPlugin 这个值-->...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<!--index.html--><%= require('html-loader!./partials/header.html') %>html里可以写img支持打包到build,如果不写的话是无法打包的,除非你在js里面require
<img src="<%= require('../src/imgs/phone.png') %>" alt="">后面还要取消hash之类的配置,这个就不记录了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前言create-react-app是由React官方提供并推荐使用构建新的React单页面应用程序的最佳方式,其构建的项目默认是不支持less的,需要我们手动
前提条件请先进行全局安装create-react-app插件哈,安装命令:npminstallcreate-react-app-g先使用create-react
使用antd按需加载使用react-app-rewired对create-react-app的默认配置进行自定义1、yarnaddreact-app-rewir
前言使用create-react-app脚手架创建项目后,默认是不支持less的。所以我们需要手动添加。第一步暴露webpack配置文件使用create-rea
说在前面create-react-app是由React官方提供并推荐使用构建新的React单页面应用程序的最佳方式,不过目前版本(1.5.x)其构建的项目中默认