配置模块
配置webpack.config.js
,注意配置中的逗号,
,我因为少了一个导致build失败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
45const path = require('path')
const { VueLoaderPlugin } = require('vue-loader')
module.exports = {
entry: path.join(__dirname, 'src/index.js'),
output: {
filename: 'bundle.js',
path: path.join(__dirname, 'dist')
},
module: {
rules: [
{ test: /\.vue$/, loader: 'vue-loader' },
{ test: /\.vue\.html$/, loader: 'vue-loader' },
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
},
{
test: /\.styl/,//支持css预处理
use: [
'style-loader',
'css-loader',
'stylus-loader'
]
},
{
test: /\.(gif|jpg|jpeg|png|svg)$/,//匹配图片文件
use: [
{
options: {
limit: 1024,//限制图片大小,符合标准的将会使用base64编码以减少请求
name: '[name].[ext]'//文件重命名,名称+后缀
}
}
]
}
]
},
plugins: [
new VueLoaderPlugin()
]
}
上面代码引用的模块有style-loader
,css-loader
,stylus-loader
,url-loader
,用于处理css样式以及文件名称
需要安装依赖的包1
npm i style-loader css-loader stylus-loader url-loader filse-loader
引入模块
1 | import Vue from 'vue' |
打包生成
1 | npm run build |
生成后会在dist/bundle.js
中发现静态资源css和小图片文件被加载到同一个js文件中,webpack为我们处理了相关的静态资源