亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

webpack手動配置React開發環境的步驟

2019-11-19 13:34:54
字體:
來源:轉載
供稿:網友

React提供了create-react-app的快速構建工具, 但作為一個專業的程序員(老司機), 面對復雜的項目, 入門級的構建工具, 是遠遠不夠的, 我們這里從零開始, 用webpack, 手動配置一個獨立的React開發環境, 開發環境完成后, 支持自動構建, 自動刷新, sass語法 等功能...

1. 首先用npm初始化環境

mkdir react-webpack-democd react-webpack-demonpm init -y

安裝相關軟件包

npm install react react-dom webpack webpack-cli webpack-dev-server html-webpack-plugin -Dnpm install babel-core babel-loader babel-plugin-transform-runtime -Dnpm install babel-preset-env babel-preset-stage-0 babel-preset-react -D# 識別html轉換為jsx語法npm install babel-preset-react -D

2.添加對html靜態文件的支持

  1. 在根目錄下新建文件夾src, 在src內加入index.html  index.js
  2. 在根目錄下新建webpack.config.js
  3. 在webpack.config.js中加入如下配置
const path = require('path');const HtmlWebpackPlugin = require('html-webpack-plugin');// 負責將html文檔虛擬到根目錄下let htmlWebpackPlugin = new HtmlWebpackPlugin({  // 虛擬的html文件名 index.html  filename: 'index.html',  // 虛擬html的模板為 src下的index.html  template: path.resolve(__dirname, './src/index.html')})module.exports = {  // 開發模式  mode: 'development',  // 配置入口文件  entry: './src/index.js',  // 出口文件目錄為根目錄下dist, 輸出的文件名為main  output: {    path: path.resolve(__dirname, 'dist'),    filename: 'main.js'  },  // 配置開發服務器, 并配置自動刷新  devServer: {    // 根目錄下dist為基本目錄    contentBase: path.join(__dirname, 'dist'),    // 自動壓縮代碼    compress: true,    // 服務端口為1208    port: 1208,    // 自動打開瀏覽器    open: true  },  // 裝載虛擬目錄插件  plugins: [htmlWebpackPlugin],}

在package.json內scripts中添加"dev": "webpack-dev-server"

在src/index.html中添加內容

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>react-webpack-demo</title></head><body>  react-webpack-demo  <hr>  高堂明鏡悲白發, 朝如青絲暮成雪</body></html>

在命令行內運行npm run dev, 即可看到剛添加的index.html內容

接下來我們配置babel對es6語法的支持, 以及對jsx語法的支持

3. 添加對js高級語法的支持

在項目根目錄, 添加.babelrc配置文件 presets為語法配置,plugins為插件配置

{  "presets": ["env", "stage-0", "react"],  "plugins": ["transform-runtime"]}

在webpack.config.js中添加module字段, 進行插件loader配置

// webpack.config.jsmodule.exports = {  ...  // 配置loader  module: {    // 根據文件后綴匹配規則    rules: [      // 配置js/jsx語法解析      { test: //.js|jsx$/, use: 'babel-loader', exclude: /node_modules/ }    ]  }};

在src/index.html中加入id為root的div節點

<!DOCTYPE html><html lang="en"><head>  <meta charset="UTF-8">  <title>react-webpack-demo</title></head><body>  react-webpack-demo  <hr>  高堂明鏡悲白發, 朝如青絲暮成雪  <hr>  <div id="root"></div></body></html>

在src/index.js中加入包含jsx語法的react組件

import React from 'react';import ReactDOM from 'react-dom';class Counter extends React.Component {  constructor(props) {    super(props);    this.state = { number: 0 };    this.decrease = this.decrease.bind(this);    this.increase = this.increase.bind(this);  }  // 加1  increase() {    let self = this;    self.setState({ number: self.state.number + 1 })  }  // 減一  decrease() {    let self = this;    self.setState({ number: self.state.number - 1 })  }  render() {    return (       <div>        <input type = "button" value = "減1"onClick = { this.decrease }/>         <span> { this.state.number } </span>        <input type = "button" value = "加1" onClick = { this.increase }/>       </div> )  }}ReactDOM.render(<Counter /> , document.getElementById('root'))

附錄: 添加對sass語法的支持(沒興趣可以跳過)

安裝sass相關的loader

npm install style-loader css-loader node-sass sass-loader -D

在webpack.config.js內新增規則

// webpack.config.jsmodule.exports = {  ...  module: {    rules: [{      test: //.scss$/,      use: [        "style-loader", // creates style nodes from JS strings        "css-loader", // translates CSS into CommonJS        "sass-loader" // compiles Sass to CSS      ]    }]  }};

在src內新增index.scss

$designWidth: 750;@function px2rem($px) { @return $px*10/$designWidth + rem;}#root {  div {    font-size: px2rem(500);    display: flex;    color: #64B587;    input {      flex: 1 1 auto;    }    span {      flex: 1 1 auto;      text-align: center;    }  }}

在index.js中新增import index.scss

最終效果:

文中相關資源鏈接:鏈接: https://pan.baidu.com/s/10PYXo_WoIScn-IFRdtuc5w 密碼: td78

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一区中文字幕在线观看| 中文字幕日本精品| 亚洲一区第一页| 日韩免费观看高清| 亚洲三级免费看| 国产精品96久久久久久又黄又硬| 欧美性猛交xxxx乱大交极品| 91中文字幕一区| 国产91精品久久久久久久| 亚洲自拍小视频免费观看| xvideos亚洲人网站| www.国产一区| 亚洲国产精品久久91精品| 欧美大片大片在线播放| 8x海外华人永久免费日韩内陆视频| 国产一区二区三区在线观看视频| 一本色道久久综合狠狠躁篇的优点| 成人黄色片网站| 久久久久久久一区二区三区| 青青草原成人在线视频| 久久99精品视频一区97| 97超级碰碰人国产在线观看| 欧美精品一区二区免费| 亚洲欧美国产高清va在线播| 亚洲大尺度美女在线| 国产精品免费一区二区三区都可以| 成人黄色短视频在线观看| 尤物九九久久国产精品的分类| 久久久最新网址| 国产一区二区三区在线播放免费观看| 欧美日韩一二三四五区| 欧美视频二区36p| 97精品在线视频| 国产精品久久久久久婷婷天堂| 国产91ⅴ在线精品免费观看| 欧美专区在线播放| 中文字幕亚洲图片| 亚洲国产欧美自拍| xxx成人少妇69| 狠狠做深爱婷婷久久综合一区| 亚洲大尺度美女在线| 激情av一区二区| 国产亚洲人成a一在线v站| 亚洲第一在线视频| 亚洲综合在线小说| 81精品国产乱码久久久久久| 国产精品扒开腿做爽爽爽男男| 国产精品自拍小视频| 欧美激情乱人伦一区| 26uuu亚洲国产精品| 亚洲精品国产电影| 亚洲综合一区二区不卡| 亚洲美女喷白浆| 欧美一级片久久久久久久| 日韩经典中文字幕| 亚洲成人动漫在线播放| 国产日韩在线精品av| 日本精品中文字幕| 在线观看国产精品91| 日韩中文字幕在线视频| 亚洲第一黄色网| 欧美日韩亚洲激情| 亚洲色图15p| 成人久久久久久| 欧美麻豆久久久久久中文| 国产精品爽爽爽爽爽爽在线观看| 久久精品国产电影| 欧美在线免费观看| 国产激情999| 久久人91精品久久久久久不卡| 久久夜色精品国产亚洲aⅴ| 欧美电影院免费观看| 91chinesevideo永久地址| 亚洲va欧美va在线观看| 欧美一级高清免费播放| 尤物九九久久国产精品的特点| 欧美中文在线观看国产| 日韩电影在线观看免费| 国产欧美精品日韩精品| 色99之美女主播在线视频| 国产精品久久久久久亚洲影视| 欧美激情亚洲激情| 久久精品久久久久久国产 免费| 亚洲一区二区免费| 亚洲白拍色综合图区| 国自在线精品视频| 久久国产精品网站| 91亚洲午夜在线| 日韩欧美国产中文字幕| 欧美亚洲国产日韩2020| 欧美精品在线第一页| 日韩电影中文字幕av| 日本国产高清不卡| 日本高清久久天堂| 97精品国产97久久久久久免费| 综合av色偷偷网| 亚洲性无码av在线| 日韩欧美精品中文字幕| 一区二区三区 在线观看视| 国产大片精品免费永久看nba| 精品露脸国产偷人在视频| 国产精品日韩在线播放| 国产精品电影网| 欧美日韩人人澡狠狠躁视频| 91久久久久久久| 精品国产自在精品国产浪潮| 精品无人国产偷自产在线| 精品国产欧美成人夜夜嗨| 国产在线精品一区免费香蕉| 欧美日韩性视频| 久久九九热免费视频| 国产精品aaaa| 精品国内产的精品视频在线观看| 欧美性猛交99久久久久99按摩| 亚洲娇小xxxx欧美娇小| 91免费国产视频| 精品国产91久久久| 在线看日韩欧美| 久久成人免费视频| 国内精品中文字幕| 欧美多人爱爱视频网站| 国产97色在线| 欧美黑人一级爽快片淫片高清| 成人久久久久爱| 热久久免费国产视频| 国产精品美女www爽爽爽视频| 亚洲一区美女视频在线观看免费| 国产精品嫩草影院一区二区| 国产高清视频一区三区| 久久久久久久影视| 亚洲国产精品久久久久秋霞蜜臀| 韩剧1988在线观看免费完整版| 亚洲精品网址在线观看| 久久韩国免费视频| 国产一区二区免费| 日韩av一卡二卡| 91av视频在线免费观看| 国产日本欧美在线观看| 欧美午夜美女看片| 91欧美精品午夜性色福利在线| 欧美老少做受xxxx高潮| 久久综合久久八八| 欧美一区二区视频97| 欧美精品日韩www.p站| 久久99精品久久久久久噜噜| 亚洲成人动漫在线播放| 国产精品久久久久99| 美女扒开尿口让男人操亚洲视频网站| 欧美日韩色婷婷| 久久精品久久久久电影| 久热在线中文字幕色999舞| 日韩av大片免费看| 欧美做受高潮1| 亚洲97在线观看| 亚洲在线观看视频网站| 7777精品久久久久久| 米奇精品一区二区三区在线观看| 成人黄色午夜影院| 在线播放国产一区二区三区| 国产午夜精品免费一区二区三区| 久久精品亚洲一区| 欧美日韩在线视频一区二区| 日韩av中文在线| 日韩在线观看你懂的|