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"
}
}

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

  1. 解放F5——React开启模块热更新

    解放F5--React开启模块热更新 在一个正在开发的应用中,刷新页面将会降低你的生产效率:你必须得等待页面加载完毕. 一个大的应用可能会花很多秒钟才能刷新完页面.使用 HMR(模块热替换) 可以避免 ...

  2. create-react-app react-redux项目 配置模块热更新hmr

    HRM并不是create-react-app专属的,提供一篇博客介绍hrm http://chrisshepherd.me/posts/adding-hot-module-reloading-to-c ...

  3. ionic2新手入门整理,搭建环境,创建demo,打包apk,热更新,优化启动慢等避坑详解

    onic官方文档链接:http://ionicframework.com/docs/ 如果是新的环境会有很多坑,主要是有墙,请仔细阅读每个步骤 文档包含以下内容: l  环境搭建 l  创建demo并 ...

  4. webpack配置(使用react,es6的项目)

    const path = require('path');const webpack = require('webpack');const HtmlWebpackPlugin = require('h ...

  5. webpack(二)解析es6并打包

    一.前言 ECMAScript 6(ES6)的发展速度非常之快,但现代浏览器对ES6新特性支持度不高,所以要想在浏览器中直接使用ES6的新特性就得借助别的工具来实现.Babel是一个广泛使用的转码器, ...

  6. walle多渠道打包+Tinker(bugly)热更新集成+360加固(乐固)

    这三个东东是干啥的相信大家都有所耳闻了,如果你没有听说过,请出门左拐,百度一下你就知道.这里不对这三个东东具体的集成方式做详细的介绍,因为官方文档已经写的很详细了,主要是对同时使用这三个东东时所需要注 ...

  7. Egret打包App Android热更新(4.1.0)

    官网教程:http://developer.egret.com/cn/github/egret-docs/Native/native/hotUpdate/index.html 详细可看官网教程,我这里 ...

  8. webpack的热更新

    webpack的热更新是如何做到的?说明其原理? webpack的热更新又称热替换(Hot Module Replacement),缩写为HMR. 这个机制可以做到不用刷新浏览器而将新变更的模块替换掉 ...

  9. webpack 配置react脚手架(二):热更新

    下面继续配置 webpack dev server    hot module replacement: 首先配置dev-server     安装     npm i webpack-dev-ser ...

随机推荐

  1. Android常用的颜色列表 color.xml

    转自:http://blog.csdn.net/libaineu2004/article/details/41548313 <?xml version="1.0" encod ...

  2. Inotify: 高效、实时的Linux文件系统事件监控框架

      Inotify: 高效.实时的Linux文件系统事件监控框架   概要 - 为什么需要监控文件系统? 在日常工作中,人们往往需要知道在某些文件(夹)上都有那些变化,比如:   通知配置文件的改变 ...

  3. 实战weblogic集群之应用部署

    一.创建应用发布目录,上传应用包. 1.在10.70.52.11-14的/app/sinova目录下建立applications目录(名称可以自定义),作为我们应用的发布目录. $ mkdir /ap ...

  4. 【转】java提高篇(二三)-----HashMap

    原文网址: http://www.cnblogs.com/chenssy/p/3521565.html HashMap也是我们使用非常多的Collection,它是基于哈希表的 Map 接口的实现,以 ...

  5. 后缀自动机(SAM):SPOJ Longest Common Substring II

    Longest Common Substring II Time Limit: 2000ms Memory Limit: 262144KB A string is finite sequence of ...

  6. 【动态规划】Vijos P1011 清帝之惑之顺治

    题目链接: https://vijos.org/p/1011 题目大意: 给一张N*M的地图(N,M<=500),可从任一点开始沿上下左右走,只能走比当前低的地方.问最长能走多少格. 题目思路: ...

  7. qt项目转vs项目

    Qt creator是一个非常好用的跨平台项目管理工具和集成开发环境(IDE).但是对于我自己来说Visual Studio依然是我最顺手的开发工具,由于Qt使用了moc,这样要是自己管理Visual ...

  8. cf601A The Two Routes

    A. The Two Routes time limit per test 2 seconds memory limit per test 256 megabytes input standard i ...

  9. LeetCode--判断二叉树是否对称

    主要是检查该二叉树是否是自己的一个镜像(也就是以中心轴对称的) 举例来说,下面显示的就是一个对称的二叉树 1 / \ 2 2 / \ / \ 3 4 4 3 下面显示的就不是一个对称的二叉树了 1 / ...

  10. [tools] sublime 使用记录

    1. 目录下的文本搜索功能(自带) 1). 把文件夹拖到 sublime 上 2). 在 sublime 上展开要搜索的目录,右击,选择[find in folder] 2. sublime cons ...