webpack 配置 (支持 React SCSS ES6 编译打包 和 模块热更新 / 生成SourceMap)

1、首先是目录结构
|-node_modules/                  #包文件
|-build/                         #静态资源生成目录
|-src/                           #开发目录
    |-js/
        |-index.js               #入口文件
        |-app.js                 #React组件文件
    |-css/
        |-style.scss             #SASS样式文件
|-webpack.config.js              #webpack开发配置文件
|-index.html
|-package.json        
2、webpack配置文件 !important
  • entry 入口文件地址:
entry:{
    build:"./src/js/index.js"
}

入口文件用来引用其他依赖,最终webpack会把所有依赖打包输出;
入口文件index.js类似这样:

import React, { Component, PropTypes, cloneElement } from 'react';
import ReactDOM from 'react-dom';
import styles from '../css/style.scss';
import App from './app';

ReactDOM.render(<App />, document.getElementById('root'));

起初没有index.js,入口文件为app.js;
app.js最后末尾执行ReactDOM.render,App组件不作为模块输出export, 这样做修改app.js会刷新整个页面,app.js无法进行模块热更新;
最终改为app.js作为模块输出export,用index.js作为入口文件,执行ReactDOM.render渲染DOM.

  • output 输出目录
path:打包输出目录

filename:
打包输出的文件名 
具体文件名xxx.js或[name].js
[name]为入口entry对象中KEY值 build

publicPath:主要是用在webpack-dev-server,设置bundle的生成路径
publicPath:'/bundle/'
在使用webpack-dev-server时,
index.html中通过<script src="/bundle/build.js"></script>引用bundle
  • module.loaders 设置各种webpack loader
module:{
   loaders:{   
            //文件名匹配成功的文件-->执行loaders
            test: /\.jsx?$/, 
            //设置路径范围
            include: [
            path.resolve(__dirname, './src/js'),
            ],
            //需要执行的loaders
                loaders: ['react-hot', 'babel'],
            }
}

编译打包React ES6 需要用到react-hot-loader babel-loader
编译打包SCSS css 需要用到style-loader css-loader sass-loader
以 loaders: ['react-hot', 'babel'] 为例
loaders的执行顺序是从右到左:先babel编译,然后执行react-hot模块热更新

  • resolve 设置模块扩展名,和依赖的路径

不设置扩展名如'.jsx', 在引入模块时会找不到.jsx文件导致报错

resolve: {
    alias: {
      'react': path.join(__dirname, 'node_modules', 'react'),
    },
    extensions: ['', '.js', '.jsx', '.scss', '.css'],
},
  • devServer : WDS服务器相关配置
devServer:{
    historyApiFallback:true,
    hot:true, //热更新
    inline:true, //热更新inline模式
    progress:true,
    port:8888 //设置webpack-dev-server端口
}
  • devtool : 设置SourceMap的生成模式

webpack 有多种SourceMap生成模式
推荐使用cheap-module-eval-source-map

devtool: 'cheap-module-eval-source-map'
完整webpack配置文件 webpack.config.js
let path = require('path');
let webpack = require('webpack');
let sassLoader = 'style!css!sass?sourceMap=true&sourceMapContents=true';
module.exports = {
    devtool: 'cheap-module-eval-source-map',
    entry:{
        build:"./src/js/index.js"
    },
    output:{
        path: path.resolve(__dirname,"./build"),
        filename:"build.js",
        publicPath: '/bundle/',
    },
    module:{
        loaders:[
            {
                test: /\.jsx?$/i, 
                include: [
                    path.resolve(__dirname, './src/js'),
                ],
                loaders: ['react-hot', 'babel'],
            },
            {
                test: /\.scss$/i,
                include: [
                path.resolve(__dirname, './src/css'),
                ],
                loader: sassLoader
            }
        ]
    },  
    resolve: {
        alias: {
          'react': path.join(__dirname, 'node_modules', 'react'),
        },
        extensions: ['', '.js', '.jsx', '.scss', '.css'],
    },
    devServer:{
        historyApiFallback:true,
        hot:true,
        inline:true,
        progress:true,
        port:8888 //webpack-dev-server端口
    }
}
3、最后是我的package.json文件
{
  "name": "moudel",
  "version": "1.0.0",
  "description": "",
  "main": "webpack.cofing.js",
  "directories": {
    "test": "test"
  },
  "scripts": {
    "bd": "webpack",
    "min": "webpack -p",
    "watch": "webpack --watch",
    "hot": "webpack-dev-server --hot --inline"
  },
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "async-each": "^1.0.1",
    "babel-core": "^6.18.2",
    "babel-loader": "^6.2.8",
    "babel-plugin-react-transform": "^2.0.2",
    "babel-plugin-transform-class-properties": "^6.19.0",
    "babel-preset-latest": "^6.16.0",
    "babel-preset-react": "^6.16.0",
    "chalk": "^1.1.3",
    "classnames": "^2.2.5",
    "css-loader": "^0.26.1",
    "express": "^4.14.0",
    "extract-text-webpack-plugin": "^1.0.1",
    "html-webpack-plugin": "^2.24.1",
    "lodash.clonedeep": "^4.5.0",
    "node-sass": "^3.13.0",
    "react": "^15.4.1",
    "react-hot-loader": "^1.3.1",
    "react-transform-catch-errors": "^1.0.2",
    "redbox-react": "^1.3.3",
    "sass-loader": "^4.0.2",
    "style-loader": "^0.13.1",
    "webpack": "^1.13.3",
    "webpack-dev-middleware": "^1.8.4",
    "webpack-dev-server": "^1.16.2",
    "webpack-hot-middleware": "^2.13.2"
  },
  "dependencies": {
    "react-dom": "^15.4.1",
    "react-redux": "^4.4.6",
    "react-router": "^3.0.0",
    "redux": "^3.6.0",
    "redux-thunk": "^2.1.0"
  }
}

转载于:https://www.cnblogs.com/king2016/p/6185454.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值