webpack4升级

2024-01-24 20:48
文章标签 升级 webpack4

本文主要是介绍webpack4升级,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1、安装webpack-cli、webpack

"webpack": "^4.39.3"

"webpack-cli": "^3.3.7"

  • npm run dev报错
  • 因为 webpack 和 webpack-dev-server 版本不兼容,升级   "webpack-dev-server": "^3.1.4"
  • 再次启动,报错
  • 因为 html-webpack-plugin 版本不兼容 安装 "html-webpack-plugin": "^3.2.0",再次启动
  • 升级 "vue-loader": "^15.0.10"    再次启动
  • 最新版的 vue-loader 需要加一个新的配置 VueLoaderPlugin
  • // webpack.dev.conf.js
    // 引入
    const { VueLoaderPlugin } = require('vue-loader')

    // 在下面的插件中加入
    plugins: [
        new VueLoaderPlugin(),
    ]


    // webpack.prod.conf.js 文件同样
    // 引入
    const { VueLoaderPlugin } = require('vue-loader')

    // 在下面的插件中加入
    plugins: [
        new VueLoaderPlugin(),
    ]

  • 再次启动

  • dev环境升级完成

  • 运行npm run build报错

  • 因为  webpack.optimize.CommonsChunkPlugin 已经被弃用,需要使用新的配置 config.optimization.splitChunk

     

    // webpack.prod.conf.js
    // 在 plugins 同级下添加配置
    optimization: {
       splitChunks: {
         cacheGroups: {
           vendor: {
             test: /[\\/]node_modules[\\/]/,
             name: 'vendor',
             chunks: 'all'
           },
           manifest: {
             name: 'manifest',
             minChunks: Infinity
           },
         }
       },
     },
     plugins: [...]

    // 去掉 plugins 中的这部分代码
    new webpack.optimize.CommonsChunkPlugin({
       name: 'vendor',
       minChunks (module) {
         // any required modules inside node_modules are extracted to vendor
         return (
           module.resource &&
           /\.js$/.test(module.resource) &&
           module.resource.indexOf(
             path.join(__dirname, '../node_modules')
           ) === 0
         )
       }
     }),
     // extract webpack runtime and module manifest to its own file in order to
     // prevent vendor hash from being updated whenever app bundle is updated
     new webpack.optimize.CommonsChunkPlugin({
       name: 'manifest',
       minChunks: Infinity
     }),
     // This instance extracts shared chunks from code splitted chunks and bundles them
     // in a separate chunk, similar to the vendor chunk
     // see: https://webpack.js.org/plugins/commons-chunk-plugin/#extra-async-commons-chunk
     new webpack.optimize.CommonsChunkPlugin({
       name: 'app',
       async: 'vendor-async',
       children: true,
       minChunks: 3
     },

  • 再次运行

  • 因为官方已经不推荐使用 extract-text-webpack-plugin 提取 css 样式,可以使用 mini-css-extract-plugin 替代

  • // 首先安装  mini-css-extract-plugin@0.8.0
    // 并且去掉 package.json 中的包 "extract-text-webpack-plugin": "^4.0.0-beta.0",

    // webpack.base.conf.js

    // 去掉 extract-text-webpack-plugin
    // const ExtractTextPlugin = require('extract-text-webpack-plugin')

    // 引入
    const MiniCssExtractPlugin = require('mini-css-extract-plugin')

    // 下面的 generateLoaders 函数更改配置(*中间的为改动部分)
    function generateLoaders (loader, loaderOptions) {
       const loaders = options.usePostCSS ? [cssLoader, postcssLoader] : [cssLoader]

       if (loader) {
         loaders.push({
           loader: loader + '-loader',
           options: Object.assign({}, loaderOptions, {
             sourceMap: options.sourceMap
           })
         })
       }

       // Extract CSS when that option is specified
       // (which is the case during production build)
       if (options.extract) {

       // ********************
       // 改动在这里
         return [MiniCssExtractPlugin.loader].concat(loaders)
       // ********************

       } else {
         return ['vue-style-loader'].concat(loaders)
       }
     }

    // webpack.prod.conf.js

    // 去掉 extract-text-webpack-plugin
    // const ExtractTextPlugin = require('extract-text-webpack-plugin')

    // 引入
    const MiniCssExtractPlugin = require('mini-css-extract-plugin')

    // 去掉 plugins 里的配置
    new ExtractTextPlugin({
       filename: utils.assetsPath('css/[name].[contenthash].css'),
       allChunks: true,
     }),

    // 然后加入新的插件配置
    new MiniCssExtractPlugin({
       filename: utils.assetsPath('css/[name].[contenthash:12].css'),
       allChunks: true,
     }),

  • 再次启动

  • webpack4 需要指定打包的模式 (mode),指定一下就好,可以在 package.json 的命令中指定,也可以写入配置

     

    // webpack.dev.conf.js
    const webpackConfig = merge(baseWebpackConfig, {
        mode: 'development',
        module: {...}
    }


    // webpack.prod.conf.js 
    const webpackConfig = merge(baseWebpackConfig, {
        mode: 'production',
        module: {...}
    }

  • Cannot assign to read only property 'exports' of object '#' (mix require and export) #4039

  • .babellrc中添加插件"transform-es2015-modules-commonjs"

 

这篇关于webpack4升级的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/640953

相关文章

升级至三频BE12000! 华硕ROG魔盒Pro路由器首发拆解评测

《升级至三频BE12000!华硕ROG魔盒Pro路由器首发拆解评测》华硕前两天推出新一代电竞无线路由器——ROG魔盒Pro(StrixGR7Pro),该产品在无线规格、硬件配置及功能设计上实现全... 作为路由器行业的T1梯队厂商,华硕近期发布了新旗舰华硕ROG魔盒Pro,除了保留DIY属性以外,高达120

Python包管理工具pip的升级指南

《Python包管理工具pip的升级指南》本文全面探讨Python包管理工具pip的升级策略,从基础升级方法到高级技巧,涵盖不同操作系统环境下的最佳实践,我们将深入分析pip的工作原理,介绍多种升级方... 目录1. 背景介绍1.1 目的和范围1.2 预期读者1.3 文档结构概述1.4 术语表1.4.1 核

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

华为鸿蒙HarmonyOS 5.1官宣7月开启升级! 首批支持名单公布

《华为鸿蒙HarmonyOS5.1官宣7月开启升级!首批支持名单公布》在刚刚结束的华为Pura80系列及全场景新品发布会上,除了众多新品的发布,还有一个消息也点燃了所有鸿蒙用户的期待,那就是Ha... 在今日的华为 Pura 80 系列及全场景新品发布会上,华为宣布鸿蒙 HarmonyOS 5.1 将于 7

ubuntu系统使用官方操作命令升级Dify指南

《ubuntu系统使用官方操作命令升级Dify指南》Dify支持自动化执行、日志记录和结果管理,适用于数据处理、模型训练和部署等场景,今天我们就来看看ubuntu系统中使用官方操作命令升级Dify的方... Dify 是一个基于 docker 的工作流管理工具,旨在简化机器学习和数据科学领域的多步骤工作流。

将Mybatis升级为Mybatis-Plus的详细过程

《将Mybatis升级为Mybatis-Plus的详细过程》本文详细介绍了在若依管理系统(v3.8.8)中将MyBatis升级为MyBatis-Plus的过程,旨在提升开发效率,通过本文,开发者可实现... 目录说明流程增加依赖修改配置文件注释掉MyBATisConfig里面的Bean代码生成使用IDEA生

linux环境openssl、openssh升级流程

《linux环境openssl、openssh升级流程》该文章详细介绍了在Ubuntu22.04系统上升级OpenSSL和OpenSSH的方法,首先,升级OpenSSL的步骤包括下载最新版本、安装编译... 目录一.升级openssl1.官网下载最新版openssl2.安装编译环境3.下载后解压安装4.备份

怎么关闭Ubuntu无人值守升级? Ubuntu禁止自动更新的技巧

《怎么关闭Ubuntu无人值守升级?Ubuntu禁止自动更新的技巧》UbuntuLinux系统禁止自动更新的时候,提示“无人值守升级在关机期间,请不要关闭计算机进程”,该怎么解决这个问题?详细请看... 本教程教你如何处理无人值守的升级,即 Ubuntu linux 的自动系统更新。来源:https://

你的华为手机升级了吗? 鸿蒙NEXT多连推5.0.123版本变化颇多

《你的华为手机升级了吗?鸿蒙NEXT多连推5.0.123版本变化颇多》现在的手机系统更新可不仅仅是修修补补那么简单了,华为手机的鸿蒙系统最近可是动作频频,给用户们带来了不少惊喜... 为了让用户的使用体验变得很好,华为手机不仅发布了一系列给力的新机,还在操作系统方面进行了疯狂的发力。尤其是近期,不仅鸿蒙O