-
Notifications
You must be signed in to change notification settings - Fork 190
/
Copy pathwebpack.dev.js
88 lines (86 loc) · 2.1 KB
/
webpack.dev.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
const path = require('path')
const webpack = require('webpack')
const { merge } = require('webpack-merge')
const ReactRefreshWebpackPlugin = require('@pmmmwh/react-refresh-webpack-plugin')
const portfinder = require('portfinder')
const common = require('./webpack.common.js')
const devProxy = require('./dev.proxy')
const devWebpackConfig = merge(common, {
mode: 'development',
devtool: 'eval-cheap-module-source-map',
cache: { type: 'memory' },
devServer: {
allowedHosts: 'all',
historyApiFallback: true,
client: {
logging: 'error',
progress: true,
overlay: {
errors: true,
warnings: false,
},
},
static: {
directory: path.join(__dirname, '../public'),
},
compress: true,
// open: true,
hot: true,
proxy: devProxy,
},
// watch: true,
// watchOptions: {
// aggregateTimeout: 500,
// poll: 1000,
// ignored: /node_modules/,
// },
module: {
rules: [
{
test: /\.(js|ts|jsx|tsx)$/,
exclude: /node_modules/,
use: [
{
loader: 'babel-loader',
options: {
presets: ['@babel/preset-env'],
plugins: [require.resolve('react-refresh/babel')].filter(Boolean),
},
},
],
},
],
},
plugins: [
new ReactRefreshWebpackPlugin({
overlay: false,
}),
// new webpack.debug.ProfilingPlugin({
// outputPath: path.join(__dirname, 'profiling/profileEvents.json'),
// }),
].filter(Boolean),
optimization: {
removeAvailableModules: false,
removeEmptyChunks: false,
splitChunks: false,
minimize: false,
concatenateModules: false,
usedExports: false,
},
})
module.exports = new Promise((resolve, reject) => {
portfinder.getPort(
{
port: 8080, // 默认8080端口,若被占用,重复+1,直到找到可用端口或到stopPort才停止
stopPort: 65535, // maximum port
},
(err, port) => {
if (err) {
reject(err)
return
}
devWebpackConfig.devServer.port = port
resolve(devWebpackConfig)
}
)
})