webpack构建react多页面应用详解

前端之家收集整理的这篇文章主要介绍了webpack构建react多页面应用详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

利用creat-react-app 新建一个react应用

然后创建一个项目

create-react-app会自动初始化一个脚手架并安装 React 项目的各种必要依赖,如果在过程中出现网络问题,请用cnpm淘宝镜像安装。

然后我们进入项目并启动。

然后启动项目

那就会看到如下页面

然后进入src/App.js,用下面代码替换App.js中的代码(因为在webpack中暂时不想处理图片和icon)

class App extends Component {
render() {
return (
<div className="App">
<div className="App-header">

Welcome to App

src/App.js and save to reload.

); } }

export default App

然后将 index.js 中的 内容替换为如下代码(删除registerServiceWorker)

ReactDOM.render(,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中的内容用如下内容替换

<Meta charset="utf-8"> <Meta name="viewport" content="width=device-width,initial-scale=1,shrink-to-fit=no"> <Meta name="theme-color" content="#000000"> React App

这个index.html就是我们的模版html。

进入正题,开始install webpack和配置webpack

1.安装依赖。将package.json文件用下面的文件替代

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,然后重新在控制台执行

3.在根目录下也就是/demo下新建一个webpack.config.js文件,写入如下代码

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.然后用直接执行如下代码

成功在dist中看到你的两个页面app1和app2.

如果要自己调试用直接启用npm run start,然后在localhost:8181/app1.html查看页面进行调试。

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

猜你在找的JavaScript相关文章