forked from hypeserver/react-date-range
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.dev.config.js
79 lines (77 loc) · 2.82 KB
/
webpack.dev.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
var path = require('path')
var webpack = require('webpack')
var HtmlWebpackPlugin = require('html-webpack-plugin')
// var ExtractTextPlugin = require("extract-text-webpack-plugin");
// var autoprefixer = require('autoprefixer');
// var precss = require('precss');
// var cssgrace = require('cssgrace');
// var filterGradient = require('postcss-filter-gradient');
// var atImport = require("postcss-import");
// var postcssUrl = require("postcss-url");
module.exports = {
context: path.join(__dirname,'./examples/scripts'),
entry: {
time : './time.js',
calendar : './calendar.js',
range : './range.js',
trigger : './trigger.js',
commons : ['react','react-dom']
},
output: {
path: path.join(__dirname,'hot'),
// publicPath: "/bundles/",
filename: "[name].[hash].bundle.js",
chunkFilename: "[id].[hash].chunk.js"
},
module: {
loaders: [
{ test : /\.css$/, loader : 'style-loader!css-loader!postcss-loader' },
{ test : /\.less$/, loader : 'style-loader!css-loader!postcss-loader!less-loader'},
{ test : /\.jsx?$/, loader : 'babel', exclude: /(node_modules|bower_components)/},
{ test : /\.(png|jpg|jpeg|gif)$/, loader : "url-loader?limit=30000" },
{ test : /\.(svg|ttf|eot|svg|woff(\(?2\)?)?)(\?[a-zA-Z_0-9.=&]*)?(#[a-zA-Z_0-9.=&]*)?$/, loader : "file-loader"}
]
},
resolve : {
root : path.resolve('./')
},
postcss: function () {
return [require('autoprefixer') , require('postcss-clearfix')];
},
plugins : [
new webpack.DefinePlugin({
"process.env" : {
NODE_ENV : JSON.stringify("development")
}
}),
new webpack.optimize.CommonsChunkPlugin("commons", "[name].bundle.js"),
new webpack.HotModuleReplacementPlugin(),
new HtmlWebpackPlugin({
chunks : ['commons','time'],
template : path.join(__dirname,'examples/index.html') ,
inject: true,
filename: 'time.html',
}),
new HtmlWebpackPlugin({
chunks : ['commons','calendar'],
template : path.join(__dirname,'examples/index.html') ,
inject: true,
filename: 'calendar.html',
}),
new HtmlWebpackPlugin({
chunks : ['commons','range'],
template : path.join(__dirname,'examples/index.html') ,
inject: true,
filename: 'range.html',
}),
new HtmlWebpackPlugin({
chunks : ['commons','trigger'],
template : path.join(__dirname,'examples/index.html') ,
inject: true,
filename: 'trigger.html',
})
],
debug : true,
devtool :'#inline-source-map'
//devServer 配置在webpack.dev.server.js 中
};