|
@@ -1,6 +1,7 @@
|
|
|
-var path = require('path')
|
|
|
|
|
-var webpack = require('webpack')
|
|
|
|
|
-const { VueLoaderPlugin } = require('vue-loader')
|
|
|
|
|
|
|
+var path = require('path');
|
|
|
|
|
+var webpack = require('webpack');
|
|
|
|
|
+const { VueLoaderPlugin } = require('vue-loader');
|
|
|
|
|
+const MiniCssExtractPlugin = require('mini-css-extract-plugin');
|
|
|
const ESLintPlugin = require('eslint-webpack-plugin');
|
|
const ESLintPlugin = require('eslint-webpack-plugin');
|
|
|
|
|
|
|
|
module.exports = {
|
|
module.exports = {
|
|
@@ -22,30 +23,48 @@ module.exports = {
|
|
|
},
|
|
},
|
|
|
{
|
|
{
|
|
|
test: /\.css$/,
|
|
test: /\.css$/,
|
|
|
- use: [
|
|
|
|
|
- 'style-loader',
|
|
|
|
|
- 'css-loader'
|
|
|
|
|
- ],
|
|
|
|
|
|
|
+ use: (process.env.NODE_ENV === 'production') ? [
|
|
|
|
|
+ {
|
|
|
|
|
+ loader: MiniCssExtractPlugin.loader,
|
|
|
|
|
+ options: {
|
|
|
|
|
+ publicPath: './',
|
|
|
|
|
+ },
|
|
|
|
|
+ },
|
|
|
|
|
+ 'css-loader'] : ['style-loader', 'css-loader'],
|
|
|
},
|
|
},
|
|
|
|
|
+
|
|
|
{
|
|
{
|
|
|
|
|
+ // webpack5 通过资源模块来处理图片
|
|
|
test: /\.(png|jpg|gif|svg)$/,
|
|
test: /\.(png|jpg|gif|svg)$/,
|
|
|
- loader: 'file-loader',
|
|
|
|
|
- options: {
|
|
|
|
|
- name: '[name].[ext]?[hash]'
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
- ]
|
|
|
|
|
|
|
+ type: 'asset',
|
|
|
|
|
+ parser: {
|
|
|
|
|
+ dataUrlCondition: {
|
|
|
|
|
+ maxSize: 10240,
|
|
|
|
|
+ },
|
|
|
|
|
+ },
|
|
|
|
|
+ generator: {
|
|
|
|
|
+ filename: '[name].[contenthash][ext][query]',
|
|
|
|
|
+ },
|
|
|
|
|
+ },
|
|
|
|
|
+ {
|
|
|
|
|
+ test: /\.(eot|woff|woff2|ttf)$/,
|
|
|
|
|
+ type: 'asset/resource',
|
|
|
|
|
+ generator: {
|
|
|
|
|
+ filename: '[name].[contenthash][ext]?[hash]',
|
|
|
|
|
+ },
|
|
|
|
|
+ },
|
|
|
|
|
+ ],
|
|
|
},
|
|
},
|
|
|
|
|
|
|
|
resolve: {
|
|
resolve: {
|
|
|
alias: {
|
|
alias: {
|
|
|
'@': path.resolve(__dirname, 'packages'),
|
|
'@': path.resolve(__dirname, 'packages'),
|
|
|
},
|
|
},
|
|
|
- extensions: ['*', '.js', '.vue', '.json']
|
|
|
|
|
|
|
+ extensions: ['*', '.js', '.vue', '.json'],
|
|
|
},
|
|
},
|
|
|
|
|
|
|
|
performance: {
|
|
performance: {
|
|
|
- hints: false
|
|
|
|
|
|
|
+ hints: false,
|
|
|
},
|
|
},
|
|
|
|
|
|
|
|
// 不把第三方库打包到bundle中
|
|
// 不把第三方库打包到bundle中
|
|
@@ -54,7 +73,7 @@ module.exports = {
|
|
|
jquery: 'window.$',
|
|
jquery: 'window.$',
|
|
|
$: 'window.$',
|
|
$: 'window.$',
|
|
|
bootstrap: 'bootstrap',
|
|
bootstrap: 'bootstrap',
|
|
|
- moment: 'moment'
|
|
|
|
|
|
|
+ moment: 'moment',
|
|
|
},
|
|
},
|
|
|
|
|
|
|
|
plugins: [
|
|
plugins: [
|
|
@@ -65,5 +84,5 @@ module.exports = {
|
|
|
// 自从eslint推出--fix命令后,如果觉得eslint格式化规则已经够用的话,其实也可以不用prettier了。
|
|
// 自从eslint推出--fix命令后,如果觉得eslint格式化规则已经够用的话,其实也可以不用prettier了。
|
|
|
fix: true,
|
|
fix: true,
|
|
|
}),
|
|
}),
|
|
|
- ]
|
|
|
|
|
-}
|
|
|
|
|
|
|
+ ],
|
|
|
|
|
+};
|