全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

webpack构建react多页面应用详解

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

利用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 多页面的项目实践  # 新建一个  # 就会  # 都有  # 很难  # 很久  # 镜像  # 找一个  # 淘宝  # 请用  # 该文件  # 创建一个  # 弄个  # 大家多多  # 过程中  # 并安装  # 光看  # 默认为  # 端口号  # 多页  # 网上 


相关文章: c++ stringstream用法详解_c++字符串与数字转换利器  盐城做公司网站,江苏电子版退休证办理流程?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  如何配置WinSCP新建站点的密钥验证步骤?  如何零成本快速生成个人自助网站?  如何规划企业建站流程的关键步骤?  Android自定义listview布局实现上拉加载下拉刷新功能  长沙企业网站制作哪家好,长沙水业集团官方网站?  如何挑选最适合建站的高性能VPS主机?  建站之星上传入口如何快速找到?  巅云智能建站系统:可视化拖拽+多端适配+免费模板一键生成  制作企业网站建设方案,怎样建设一个公司网站?  建站之星会员如何解锁更多建站功能?  建站之星微信建站一键生成小程序+多端营销系统  宝塔面板创建网站无法访问?如何快速排查修复?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  linux top下的 minerd 木马清除方法  网站制作难吗安全吗,做一个网站需要多久时间?  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  建站之星展会模版如何一键下载生成?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  建站之星安装后界面空白如何解决?  C#怎么创建控制台应用 C# Console App项目创建方法  建站之家VIP精选网站模板与SEO优化教程整合指南  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  如何在企业微信快速生成手机电脑官网?  如何正确下载安装西数主机建站助手?  建站主机是否等同于虚拟主机?  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  专业型网站制作公司有哪些,我设计专业的,谁给推荐几个设计师兼职类的网站?  做企业网站制作流程,企业网站制作基本流程有哪些?  如何快速搭建安全的FTP站点?  制作表格网站有哪些,线上表格怎么弄?  建站之星安装失败:服务器环境不兼容?  如何通过主机屋免费建站教程十分钟搭建网站?  香港网站服务器数量如何影响SEO优化效果?  建站与域名管理如何高效结合?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  如何在万网开始建站?分步指南解析  如何在IIS7中新建站点?详细步骤解析  如何快速查询域名建站关键信息?  宁波自助建站系统如何快速打造专业企业网站?  如何用狗爹虚拟主机快速搭建网站?  重庆市网站制作公司,重庆招聘网站哪个好?  再谈Python中的字符串与字符编码(推荐)  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  大连 网站制作,大连天途有线官网?  网站制作大概要多少钱一个,做一个平台网站大概多少钱?  高防服务器租用如何选择配置与防御等级? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。