-
Notifications
You must be signed in to change notification settings - Fork 0
/
webpack.config.js
108 lines (106 loc) · 3.63 KB
/
webpack.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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
var path = require('path');
var webpack = require('webpack');
var ExtractTextPlugin = require("extract-text-webpack-plugin");
var HtmlWebpackPlugin = require('html-webpack-plugin');
var version = Date.now();
// NodeJS中的Path对象,用于处理目录的对象,提高开发效率。
// 模块导入
module.exports = {
// 入口文件地址,不需要写完,会自动查找
entry: ['./src/main','./src/assets/scss/common.css'],
// 输出
output: {
path: path.join(__dirname, './dist'),
// 文件地址,使用绝对路径形式
publicPath: '',
// 公共文件生成的地址
chunkFilename: 'js/[id].min.js',
filename: 'js/[name].min.js'
//[name]这里是webpack提供的根据路口文件自动生成的名字
},
// 服务器配置相关,自动刷新!
devServer: {
historyApiFallback: true,
hot: false,
inline: true,
grogress: true,
},
// 加载器
module: {
loaders: [{
test: /\.vue$/,
loader: 'vue-loader',
}, {
test: /\.css$/,
loader: ExtractTextPlugin.extract(
"style-loader", "css-loader")
}, {
test: /\.scss$/,
loader: "style!css!sass"
}, {
test: /\.less$/,
loader: "style!css!less"
},{
test: /\.js$/,
exclude: /node_modules|vue\/dist/,
loader: 'babel'
},{
test: /\.(jpg|png|gif)$/,
loader: "url-loader?limit=8192"
//loader: "file-loader?name=img/[hash:8].[name].[ext]"
}, {
test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "url-loader?limit=10000&minetype=application/font-woff"
}, {
test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "file-loader"
}, {
test: /\.json$/,
loader: 'json'
}, {
test: /\.(html|tpl)$/,
loader: 'html-loader'
}]
},
plugins:[
//提公用js到common.js文件中
new webpack.optimize.CommonsChunkPlugin('js/common.min.js'),
//将样式统一发布到style.css中
new ExtractTextPlugin('css/style.min.css'),
// 使用 ProvidePlugin 加载使用率高的依赖库
new webpack.ProvidePlugin({
$: 'webpack-zepto'
}),
new HtmlWebpackPlugin({
template: 'index.html',
minify:{ //压缩HTML文件
removeComments:true, //移除HTML中的注释
collapseWhitespace:false //删除空白符与换行符
} // Load a custom template
}),
new webpack.BannerPlugin("k.liu")//注意这是一个数组..
],
// .vue的配置。需要单独出来配置,其实没什么必要--因为我删了也没保错,不过这里就留这把,因为官网文档里是可以有单独的配置的。
vue: {
loaders: {
css: 'style!css!autoprefixer',
}
},
// 转化成es5的语法
babel: {
presets: ['es2015'],
plugins: ['transform-runtime']
},
resolve: {
// require时省略的扩展名,如:require('module') 不需要module.js
extensions: ['', '.js', '.vue'],
// 别名,可以直接使用别名来代表设定的路径以及其他
alias: {
filter: path.join(__dirname, './src/filters'),
components: path.join(__dirname, './src/components')
}
},
// 开启source-map,webpack有多种source-map,在官网文档可以查到
// devtool: '#source-map'
// devtool:false
};