-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwebpack.config.js
63 lines (61 loc) · 1.72 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
const path = require('path')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const { CleanWebpackPlugin } = require('clean-webpack-plugin')
module.exports = {
mode: 'development',
/*
Entrada onde o webpack vai pegar os dados para enpacotamento.
Sempre vai ser o Arquivo onde está root.render.
*/
entry: path.resolve(__dirname, 'src','index.js'),
/*
Onde o webpack vai guardar o bundle gerado
*/
output:{
path: path.resolve(__dirname,'build'),
filename: 'bundle[contenthash].js'
},
plugins:[
/*
Gera o arquivo html de public, no caso o html root e
ja escreve o bundle nele sem precisar fazer manual.
Esse bundle é gerado um a cada build
*/
new HtmlWebpackPlugin({
template: path.resolve(__dirname,'public','index.html')
}),
/*
Limpa os arquivos sem uso ,gerados no build.
No caso os bundles antigos.
*/
new CleanWebpackPlugin()
],
module:{
rules:[
/*
Para todo arquivo .js ele vai transpilar no caso
utilizando o babel-loader faz a função do build
do babel automatico.
*/
{
test:/\.js$/,
use: 'babel-loader',
exclude: /node_modules/
},
/*
para o webpack entender arquivos css.
*/
{
test: /\.css$/,
use: ['style-loader','css-loader'],
},
{
test:/\.svg$/,
use: 'svg-url-loader'
}
]
},
devServer:{
port:3001
}
}