写这个的初衷是很难找一个简洁的项目脚手架,很多脚手架都有很多依赖,光看依赖就要很久,所以自己参照网上的内容,弄个这么一个简单的多页面的脚手架。

利用creat-react-app 新建一个react应用
npm install -g create-react-app
然后创建一个项目
create-react-app demo
create-react-app会自动初始化一个脚手架并安装 React 项目的各种必要依赖,如果在过程中出现网络问题,请用cnpm淘宝镜像安装。
然后我们进入项目并启动。
cd demo
然后启动项目
npm start
那就会看到如下页面
然后进入src/App.js,用下面代码替换App.js中的代码(因为在webpack中暂时不想处理图片和icon)
import React, { Component } from 'react';
import './App.css';
class App extends Component {
render() {
return (
<div className="App">
<div className="App-header">
<h2>Welcome to App</h2>
</div>
<p className="App-intro">
To get started, edit <code>src/App.js</code> and save to reload.
</p>
</div>
);
}
}
export default App
然后将 index.js 中的 内容替换为如下代码(删除registerServiceWorker)
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
ReactDOM.render(<App />, document.getElementById('root'));
然后删除src下面的registerServiceWorker.js(该文件用于构建pwa应用用的,暂时我们用不了)和 logo.svg文件(不想处理图片文件)和 App.test.js(用于测试用的)。
现在src/下面有四个文件。接下来,在src下面新建两个文件夹 app1和 app2,分别将原来的四个文件拷贝进入app1和app2。文件目录如下:
接下来,进入public文件下,删除favicon.ico(不想处理)和 manifest.json(构建pwa用的),然后将index.html中的内容用如下内容替换
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> <meta name="theme-color" content="#000000"> <title>React App</title> </head> <body> <noscript> You need to enable JavaScript to run this app. </noscript> <div id="root"></div> </body> </html>
这个index.html就是我们的模版html。
进入正题,开始install webpack和配置webpack
1.安装依赖。将package.json文件用下面的文件替代
{
"name": "demo",
"version": "0.1.0",
"private": true,
"dependencies": {
"react": "^15.6.1",
"react-dom": "^15.6.1"
},
"devDependencies": {
"babel-core": "^6.26.0",
"babel-loader": "^7.1.2",
"babel-preset-es2015": "^6.24.1",
"babel-preset-react": "^6.24.1",
"clean-webpack-plugin": "^0.1.16",
"css-loader": "^0.28.7",
"extract-text-webpack-plugin": "^3.0.0",
"file-loader": "^1.0.0",
"glob": "^7.1.2",
"html-webpack-plugin": "^2.30.1",
"postcss-loader": "^2.0.6",
"style-loader": "^0.18.2",
"url-loader": "^0.5.9",
"webpack": "^3.5.6",
"webpack-dev-server": "^2.8.1"
},
"scripts": {
"start": "webpack-dev-server --open",
"build": "webpack"
}
}
2.删除当前目录中的node_modules,然后重新在控制台执行
npm i
3.在根目录下也就是/demo下新建一个webpack.config.js文件,写入如下代码
const webpack = require('webpack');
const glob = require('glob');
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const webpackConfig = {
entry: {},
output:{
path:path.resolve(__dirname, './dist/'),
filename:'[name].[chunkhash:6].js'
},
//设置开发者工具的端口号,不设置则默认为8080端口
devServer: {
inline: true,
port: 8181
},
module:{
rules:[
{
test:/\.js?$/,
exclude:/node_modules/,
loader:'babel-loader',
query:{
presets:['es2015','react']
}
},
{
test: /\.(scss|sass|css)$/,
loader: ExtractTextPlugin.extract({fallback: "style-loader", use: "css-loader"})
},
]
},
plugins: [
new ExtractTextPlugin("[name].[chunkhash:6].css"),
new CleanWebpackPlugin(
['dist'],
{
root: __dirname,
verbose: true,
dry: false
}
)
],
};
// 获取指定路径下的入口文件
function getEntries(globPath) {
const files = glob.sync(globPath),
entries = {};
files.forEach(function(filepath) {
const split = filepath.split('/');
const name = split[split.length - 2];
entries[name] = './' + filepath;
});
return entries;
}
const entries = getEntries('src/**/index.js');
Object.keys(entries).forEach(function(name) {
webpackConfig.entry[name] = entries[name];
const plugin = new HtmlWebpackPlugin({
filename: name + '.html',
template: './public/index.html',
inject: true,
chunks: [name]
});
webpackConfig.plugins.push(plugin);
})
module.exports = webpackConfig;
4.然后用直接执行如下代码
npm run build
成功在dist中看到你的两个页面app1和app2.
如果要自己调试用直接启用npm run start,然后在localhost:8181/app1.html查看页面进行调试。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# webpack
# react
# 多页面
# webpack构建react
# webpack4打包vue前端多页面项目
# 详解webpack4多入口、多页面项目构建案例
# 解决webpack多页面内存溢出的方法示例
# 详解webpack多页面配置记录
# vue webpack多页面构建的实例代码
# webpack打包多页面的方法
# 详解使用webpack构建多页面应用
# WebPack配置vue多页面的技巧
# Webpack5 多页面的项目实践
# 新建一个
# 就会
# 都有
# 很难
# 很久
# 镜像
# 找一个
# 淘宝
# 请用
# 该文件
# 创建一个
# 弄个
# 大家多多
# 过程中
# 并安装
# 光看
# 默认为
# 端口号
# 多页
# 网上
相关文章:
如何在宝塔面板创建新站点?
手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?
如何通过主机屋免费建站教程十分钟搭建网站?
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
建站之星如何取消后台验证码生成?
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
如何在VPS电脑上快速搭建网站?
电商网站制作公司有哪些,1688网是什么意思?
JS中使用new Date(str)创建时间对象不兼容firefox和ie的解决方法(两种)
建站之星伪静态规则如何正确配置?
非常酷的网站设计制作软件,酷培ai教育官方网站?
建站与域名管理如何高效结合?
如何在阿里云完成域名注册与建站?
音乐网站服务器如何优化API响应速度?
如何通过虚拟主机快速完成网站搭建?
建站之星如何实现五合一智能建站与营销推广?
阿里云高弹*务器配置方案|支持分布式架构与多节点部署
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
免费视频制作网站,更新又快又好的免费电影网站?
海南网站制作公司有哪些,海口网是哪家的?
英语简历制作免费网站推荐,如何将简历翻译成英文?
如何用美橙互联一键搭建多站合一网站?
北京营销型网站制作公司,可以用python做一个营销推广网站吗?
建站之星2.7模板:企业网站建设与h5定制设计专题
广州商城建站系统开发成本与周期如何控制?
建站之星备案是否影响网站上线时间?
重庆市网站制作公司,重庆招聘网站哪个好?
如何通过万网虚拟主机快速搭建网站?
如何快速生成凡客建站的专业级图册?
广州网站制作公司哪家好一点,广州欧莱雅百库网络科技有限公司官网?
建站之星后台密码如何安全设置与找回?
如何通过服务器快速搭建网站?完整步骤解析
建站之星如何优化SEO以实现高效排名?
网页设计网站制作软件,microsoft office哪个可以创建网页?
广平建站公司哪家专业可靠?如何选择?
,南京靠谱的征婚网站?
盘锦网站制作公司,盘锦大洼有多少5G网站?
如何高效生成建站之星成品网站源码?
标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南
网站建设制作、微信公众号,公明人民医院怎么在网上预约?
linux top下的 minerd 木马清除方法
安徽网站建设与外贸建站服务专业定制方案
宁波免费建站如何选择可靠模板与平台?
青浦网站制作公司有哪些,苹果官网发货地是哪里?
建站主机解析:虚拟主机配置与服务器选择指南
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
网站制作报价单模板图片,小松挖机官方网站报价?
*请认真填写需求信息,我们会在24小时内与您取得联系。