欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

webpack構(gòu)建react多頁(yè)面應(yīng)用詳解

 更新時(shí)間:2017年09月15日 14:48:37   作者:小然同學(xué)  
這篇文章主要介紹了webpack構(gòu)建react多頁(yè)面應(yīng)用詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

寫(xiě)這個(gè)的初衷是很難找一個(gè)簡(jiǎn)潔的項(xiàng)目腳手架,很多腳手架都有很多依賴,光看依賴就要很久,所以自己參照網(wǎng)上的內(nèi)容,弄個(gè)這么一個(gè)簡(jiǎn)單的多頁(yè)面的腳手架。

利用creat-react-app 新建一個(gè)react應(yīng)用

npm install -g create-react-app

然后創(chuàng)建一個(gè)項(xiàng)目

create-react-app demo

create-react-app會(huì)自動(dòng)初始化一個(gè)腳手架并安裝 React 項(xiàng)目的各種必要依賴,如果在過(guò)程中出現(xiàn)網(wǎng)絡(luò)問(wèn)題,請(qǐng)用cnpm淘寶鏡像安裝。

然后我們進(jìn)入項(xiàng)目并啟動(dòng)。

cd demo

然后啟動(dòng)項(xiàng)目

npm start

那就會(huì)看到如下頁(yè)面


然后進(jìn)入src/App.js,用下面代碼替換App.js中的代碼(因?yàn)樵趙ebpack中暫時(shí)不想處理圖片和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 中的 內(nèi)容替換為如下代碼(刪除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(該文件用于構(gòu)建pwa應(yīng)用用的,暫時(shí)我們用不了)和 logo.svg文件(不想處理圖片文件)和 App.test.js(用于測(cè)試用的)。

現(xiàn)在src/下面有四個(gè)文件。接下來(lái),在src下面新建兩個(gè)文件夾 app1和 app2,分別將原來(lái)的四個(gè)文件拷貝進(jìn)入app1和app2。文件目錄如下:


接下來(lái),進(jìn)入public文件下,刪除favicon.ico(不想處理)和 manifest.json(構(gòu)建pwa用的),然后將index.html中的內(nèi)容用如下內(nèi)容替換

<!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>

這個(gè)index.html就是我們的模版html。

進(jìn)入正題,開(kāi)始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.刪除當(dāng)前目錄中的node_modules,然后重新在控制臺(tái)執(zhí)行

npm i 

3.在根目錄下也就是/demo下新建一個(gè)webpack.config.js文件,寫(xiě)入如下代碼

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'
  },
  //設(shè)置開(kāi)發(fā)者工具的端口號(hào),不設(shè)置則默認(rèn)為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.然后用直接執(zhí)行如下代碼

npm run build

成功在dist中看到你的兩個(gè)頁(yè)面app1和app2.

如果要自己調(diào)試用直接啟用npm run start,然后在localhost:8181/app1.html查看頁(yè)面進(jìn)行調(diào)試。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • React引入css的幾種方式及應(yīng)用小結(jié)

    React引入css的幾種方式及應(yīng)用小結(jié)

    這篇文章主要介紹了React引入css的幾種方式及應(yīng)用小結(jié),操作styled組件的樣式屬性,可在組件標(biāo)簽上定義屬性、也可以通過(guò)attrs定義屬性,本文通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • React修改數(shù)組對(duì)象的注意事項(xiàng)及說(shuō)明

    React修改數(shù)組對(duì)象的注意事項(xiàng)及說(shuō)明

    這篇文章主要介紹了React修改數(shù)組對(duì)象的注意事項(xiàng)及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • React特征學(xué)習(xí)Form數(shù)據(jù)管理示例詳解

    React特征學(xué)習(xí)Form數(shù)據(jù)管理示例詳解

    這篇文章主要為大家介紹了React特征學(xué)習(xí)Form數(shù)據(jù)管理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • React Native從類組件到函數(shù)組件詳解

    React Native從類組件到函數(shù)組件詳解

    這篇文章主要介紹了React Native從類組件到函數(shù)組件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2025-03-03
  • React中style的使用及注意事項(xiàng)(推薦)

    React中style的使用及注意事項(xiàng)(推薦)

    React中style的使用和直接在HTML中使用有些不同,第一,React中必須是style="opacity:{this.state.opacity};"這種寫(xiě)法,第二如果設(shè)置多個(gè)style格式如下,多個(gè)style中間使用逗號(hào)分割,這篇文章主要介紹了React中style的使用注意事項(xiàng),需要的朋友可以參考下
    2023-02-02
  • React調(diào)度系統(tǒng)Scheduler工作原理詳解

    React調(diào)度系統(tǒng)Scheduler工作原理詳解

    這篇文章主要為大家介紹了React調(diào)度系統(tǒng)Scheduler工作原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-03-03
  • React?Native中8081端口號(hào)被占用問(wèn)題的原因及解決方案

    React?Native中8081端口號(hào)被占用問(wèn)題的原因及解決方案

    隨著移動(dòng)應(yīng)用開(kāi)發(fā)的興起,React?Native?已成為一種流行的開(kāi)發(fā)框架,然而,在開(kāi)發(fā)過(guò)程中,常常會(huì)遇到?8081?端口被占用的問(wèn)題,導(dǎo)致無(wú)法訪問(wèn)?Metro?Bundler,本文將詳細(xì)探討如何解決這一問(wèn)題,包括原因、解決方案及相關(guān)最佳實(shí)踐,需要的朋友可以參考下
    2025-06-06
  • React?diff算法超詳細(xì)講解

    React?diff算法超詳細(xì)講解

    渲染真實(shí)DOM的開(kāi)銷很大,有時(shí)候我們修改了某個(gè)數(shù)據(jù),直接渲染到真實(shí)dom上會(huì)引起整個(gè)dom樹(shù)的重繪和重排。我們希望只更新我們修改的那一小塊dom,而不是整個(gè)dom,diff算法就幫我們實(shí)現(xiàn)了這點(diǎn)。diff算法的本質(zhì)就是:找出兩個(gè)對(duì)象之間的差異,目的是盡可能做到節(jié)點(diǎn)復(fù)用
    2022-11-11
  • React項(xiàng)目配置axios和反向代理和process.env環(huán)境配置等問(wèn)題

    React項(xiàng)目配置axios和反向代理和process.env環(huán)境配置等問(wèn)題

    這篇文章主要介紹了React項(xiàng)目配置axios和反向代理和process.env環(huán)境配置等問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 如何使用Redux Toolkit簡(jiǎn)化Redux

    如何使用Redux Toolkit簡(jiǎn)化Redux

    這篇文章主要介紹了如何使用Redux Toolkit簡(jiǎn)化Redux,幫助大家更好的理解和學(xué)習(xí)使用React框架,感興趣的朋友可以了解下
    2021-04-04

最新評(píng)論