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"
}
}
webpack 配置 (支持 React SCSS ES6 编译打包 和 模块热更新 / 生成SourceMap)的更多相关文章
- 解放F5——React开启模块热更新
解放F5--React开启模块热更新 在一个正在开发的应用中,刷新页面将会降低你的生产效率:你必须得等待页面加载完毕. 一个大的应用可能会花很多秒钟才能刷新完页面.使用 HMR(模块热替换) 可以避免 ...
- create-react-app react-redux项目 配置模块热更新hmr
HRM并不是create-react-app专属的,提供一篇博客介绍hrm http://chrisshepherd.me/posts/adding-hot-module-reloading-to-c ...
- ionic2新手入门整理,搭建环境,创建demo,打包apk,热更新,优化启动慢等避坑详解
onic官方文档链接:http://ionicframework.com/docs/ 如果是新的环境会有很多坑,主要是有墙,请仔细阅读每个步骤 文档包含以下内容: l 环境搭建 l 创建demo并 ...
- webpack配置(使用react,es6的项目)
const path = require('path');const webpack = require('webpack');const HtmlWebpackPlugin = require('h ...
- webpack(二)解析es6并打包
一.前言 ECMAScript 6(ES6)的发展速度非常之快,但现代浏览器对ES6新特性支持度不高,所以要想在浏览器中直接使用ES6的新特性就得借助别的工具来实现.Babel是一个广泛使用的转码器, ...
- walle多渠道打包+Tinker(bugly)热更新集成+360加固(乐固)
这三个东东是干啥的相信大家都有所耳闻了,如果你没有听说过,请出门左拐,百度一下你就知道.这里不对这三个东东具体的集成方式做详细的介绍,因为官方文档已经写的很详细了,主要是对同时使用这三个东东时所需要注 ...
- Egret打包App Android热更新(4.1.0)
官网教程:http://developer.egret.com/cn/github/egret-docs/Native/native/hotUpdate/index.html 详细可看官网教程,我这里 ...
- webpack的热更新
webpack的热更新是如何做到的?说明其原理? webpack的热更新又称热替换(Hot Module Replacement),缩写为HMR. 这个机制可以做到不用刷新浏览器而将新变更的模块替换掉 ...
- webpack 配置react脚手架(二):热更新
下面继续配置 webpack dev server hot module replacement: 首先配置dev-server 安装 npm i webpack-dev-ser ...
随机推荐
- 关于sql server 代理(已禁用代理xp)
由于有数据库在恢复,导致计划不能执行,先操作如下: 关闭数据库的服务..然后把数据库文件剪切出来.然后在起服务.进入SqlSever删除数据库.因为文件已经剪切走了.所以不会删除文件.再把数据库拷到M ...
- 一份React-Native学习指南-感谢分享
自己在学习React-Native过程中整理的一份学习指南,包含 教程.开源app和资源网站等,还在不断更新中.欢迎pull requests! React-Native学习指南 本指南汇集React ...
- Cordova VS React Native 谁是未来? - b
对于原生native还是倍加推崇的,极佳的用户体验和性能让我学的如痴如醉,可是互联网这个世界可以用一句话可以总结:没有什么是不可能的.自从阿里淘宝天猫横空出世,它们教会了人们如何在网上购物,然后仿佛一 ...
- 转:使用Mongo Connector和Elasticsearch实现模糊匹配
原文来自于:http://www.csdn.net/article/2014-09-01/2821485-how-to-perform-fuzzy-matching-with-mongo-connec ...
- JSP出现中文乱码问题
今天纠结了好半天,本地运行程序后没有中文乱码,唯独发到服务器后运行出现了乱码. 究其原因,皆因eclipse环境默认的JSP编码是Iso-8859-1,需要将其改为utf-8,与JSP文件中的编码声明 ...
- Apache HTTP Server mod_session_dbd 远程安全漏洞(CVE-2013-2249)
漏洞版本: Apache 2.4.2 漏洞描述: BUGTRAQ ID: 61379 CVE(CAN) ID: CVE-2013-2249 Apache HTTP Server是开源HTTP服务器. ...
- Qt入门(19)——自定义窗口部件
我们介绍可以画自己的第一个自定义窗口部件.我们也加入了一个有用的键盘接口.我们添加了一个槽:setRange(). void setRange( int minVal, int maxV ...
- 【转】java提高篇(二三)-----HashMap
原文网址: http://www.cnblogs.com/chenssy/p/3521565.html HashMap也是我们使用非常多的Collection,它是基于哈希表的 Map 接口的实现,以 ...
- 【模拟】Codeforces 691C Exponential notation
题目链接: http://codeforces.com/problemset/problem/691/C 题目大意: 输入一个数,把它表示成a·10b形式(aEb).输出aEb,1<=a< ...
- Azkaban2配置过程
Azkaban2配置过程 azkaban2所需环境:jdk1.6.ant.jetty.hadoop.ssl证书 通过http://azkaban.github.io/azkaban2/download ...