webpack升级到4.x 不完全指南

最近在团队推行ts,顺便将webpack做了升级,升级到最新的4.X版本,下面记录一些迁移指南。

VueLoader#

VueLoaderPlugin,显示的引用:#

Copy
const VueLoaderPlugin = require('vue-loader/lib/plugin') module.exports = { module: { rules: [ // ... other rules { test: /\.vue$/, loader: 'vue-loader' } ] }, plugins: [ // make sure to include the plugin! new VueLoaderPlugin() ] }

less问题#

less需要单独的配置规则,注意一定要加上vue-style-loader,否则样式不生效

Copy
{ module: { rules: [ // ... other rules { test: /\.less$/, use: [ 'vue-style-loader', 'css-loader', 'less-loader' ] } ] } }

ts 支持#

加上ts-loader

Copy
{ test: /\.tsx?$/, loader: 'ts-loader', exclude: /node_modules/, options: { appendTsSuffixTo: [/\.vue$/], } },

UglifyJsPlugin#

UglifyJsPlugin 配置位置发生了变化,放到optimization里,如果不想开启minimize,可以配置minimize:false,开启优化的话,可以配置minimizer:

Copy
// webpack.optimize.UglifyJsPlugin optimization: { // minimize: false, minimizer: [ new UglifyJsPlugin({ cache: true, parallel: true, uglifyOptions: { compress: false }, sourceMap: false }) ] }

CopyWebpackPlugin#

配置发生了变化:

Copy
// copy custom static assets new CopyWebpackPlugin({ patterns: [{ from: path.resolve(__dirname, '../static'), to: config.dev.assetsSubDirectory }] })

ExtractTextPlugin#

之前:

Copy
new ExtractTextPlugin({ filename: utils.assetsPath('css/[name].[contenthash].css'), allChunks: true, }),

contenthash已不能使用,换成hash即可

Copy
new ExtractTextPlugin({ filename: utils.assetsPath('css/[name].[hash].css'), allChunks: true, }),

关注作者

欢迎关注作者微信公众号, 一起交流软件开发:欢迎关注作者微信公众号

posted @   JadePeng  阅读(703)  评论(0编辑  收藏  举报
编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示
CONTENTS