webpack4和webpack5有什么区别

前言

Webpack4和Webpack5是两个版本的Webpack,其中Webpack5是Webpack的最新版本。


一、比较

性能:Webpack5相对于Webpack4有更好的性能表现,尤其是在构建速度和Tree Shaking方面。

模块联邦:Webpack5引入了模块联邦的概念,可以让多个Webpack构建的应用程序共享模块,从而减少了代码冗余。

持久性缓存:Webpack5引入了持久性缓存,通过使用持久性哈希来生成文件名,可以更好地利用浏览器缓存,从而提高应用程序的加载速度。

解析器:Webpack5支持WebAssembly模块、JSON模块和TypeScript模块的解析。

构建输出:Webpack5支持输出多个bundle,通过设置output.chunkFilename参数来实现。

移除插件:Webpack5移除了一些不常用的插件,例如UglifyJsWebpackPlugin和CommonsChunkPlugin。

二、使用步骤

1.5缓存使用方法和构建速度对比

构建速度上 5 比 4 速度更快,
都有 cache 属性
webpack5比webpack4的文件压缩策略更优,分割文件后的vendor体积缩小
webpack5 缓存构建性能优于webpack4
webpack5 缓存的功能显著优于webpack4

4:的缓存文件只有 true false,不能从新命名之类的 所以引入插件

npm install hard-source-webpack-plugin -D
const HardSourceWebpackPlugin = require('hard-source-webpack-plugin');
new HardSourceWebpackPlugin()

在这里插入图片描述

5:

cache: {
    type: 'filesystem',
    cacheDirectory: path.join(__dirname, 'node_modules/.cac/webpack')
  },

在这里插入图片描述

2.资源模块处理

4:中处理字体图标等文件需要单独引入loader进行处理
imit: 当文件大于10000 时单独打包
在这里插入图片描述
5:maxSize: 8 * 1024

module: {
    rules: [
		{
        test: /\.(png|svg|jpg|jpeg|gif)$/i,
        type: 'asset',
        parser: {
          dataUrlCondition: {
            maxSize: 8 * 1024,
          },
        },
        generator: {
          filename: 'images/[name].[hash:6][ext]',
        },
      },

3.Webpack 5 支持在请求中处理协议。

支持data:支持 Base64 或原始编码。Mimetype 可以在module.rule中被映射到加载器和模块类型。例如:import x from “data:text/javascript,export default 42”。
支持file:支持引入本地资源文件(非项目中资源)
支持http(s):需要通过new webpack.experiments.schemesHttp(s)UriPlugin()选择加入。
默认情况下,当目标为 "web "时,这些 URI 会导致对外部资源的请求(它们是外部资源)

// data
import data from "data:text/javascript,export default 'hello webpack4'"
console.log(data)

// file
import data from "file:///Users/liumeng/Desktop/tx-classroom-resource/%E8%AF%BE%E7%A8%8B%E9%A1%B9%E7%9B%AE/webpack/webpack4/template/eslintinit.1a7d4ecc.jpg"
const addImg = document.querySelector('.addImg')
addImg.setAttribute('src',data)

// https
// webpack.config.js
experiments: {
  buildHttp: {
    allowedUris: [
      "https://fast-learn-oss.youbaobao.xyz/",
      "http://hp.hpbb.me//upload/20171108173745476048.jpeg?x-oss-process=style/thumb"
    ],
    frozen: false,
    cacheLocation: false,
    upgrade: true
  }
},
// index.html
<img  class="addImg" alt="">
<img  class="addImg2" alt="">
  
// index.js
import data from 'https://fast-learn-oss.youbaobao.xyz/tb/category6.png';
const addImg = document.querySelector('.addImg')
addImg.setAttribute('src',data)
import data2 from 'http://hp.hpbb.me//upload/20171108173745476048.jpeg?x-oss-process=style/thumb';
const addImg2 = document.querySelector('.addImg2')
addImg2.setAttribute('src',data2)

4.tree-shaking。

4:全打包
5:认为你没有使用到的引用 会不打包

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Webpack4和Webpack5的区别主要在以下几个方面: 1. 性能优化:Webpack5在构建速度和打包体积方面都有了很大的提升,尤其是在使用Tree Shaking和Code Splitting等功能时更加高效。 2. 模块联邦:Webpack5引入了模块联邦的概念,可以实现多个应用之间的模块共享,提高了代码复用性和开发效率。 3. 支持WebAssembly:Webpack5支持WebAssembly模块的导入和导出,可以更加高效地处理一些计算密集型的任务。 4. 默认值改变:Webpack5中一些默认值发生了改变,例如mode默认值从production改为了production,需要注意调整配置文件。 5. 其他改进:Webpack5还引入了一些新的特性和改进,例如支持ESLint的缓存,支持多种类型的资源模块等。 ### 回答2: Webpack是一个强大的模块打包工具,目前最新版本是Webpack5。和之前版本(Webpack4)相比,Webpack5带来了很多新的改进和特性。 其中最显著的区别是缩小了输出文件的大小和提高了构建速度。Webpack5引入了一个叫做Tree shaking的新特性,它可以去除未使用的代码,因此,输出的文件尺寸会变得更小。此外,Webpack5还引入了Module Federation,这一新特性可实现模块共享,从而使构建速度更快。 除此之外,Webpack5还带来了一些其他的改进。其中一项改进是Webpack5的缓存机制更加高效,因此重复构建时能够更快地完成。此外,Webpack5也增强了持久化缓存的能力,能够更好地存储数据。还有一项非常实用的改进是Webpack5支持0配置模式,使得开发者能够更快地开始工作。 总体而言,Webpack5与Webpack4相比,在性能和功能上都有了很大的提升。如果你正在考虑使用Webpack,我建议你选择Webpack5,因为它会让你的工作更加高效和愉快! ### 回答3: Webpack是一个广泛使用的JavaScript模块打包工具。Webpack可以将多个开发时编写的JavaScript模块汇总到一个或多个静态资源中。Webpack会创建一个整个应用程序的依赖图,使用该依赖图生成打包后的文件,并将应用程序的所有依赖项捆绑在一起。 Webpack在不断地更新迭代中,目前主要有4.x和5.x两个版本。下面就来比较一下Webpack4和Webpack5的区别。 1. 构建速度 Webpack5做了很多优化,构建速度提升了90%以上,比Webpack4快了很多。取代了Optimize CSS Assets Plugin 和 TerserWebpackPlugin两个插件均可减少构建时间。 2. Tree shaking Webpack5针对 Tree shaking优化有很多的改进,增加了 Module Graph 和深度优化,进一步的提高了 Tree shaking 的效率,把未用到的模块从最终打包的代码中删除,减小了打包后的文件大小。 3. 模块联邦 Webpack5新增了模块联邦(module federation)提供了一种新的代码共享机制,可以允许不同的应用程序之间共享代码。一个 Webpack5 主应用可以提供自己的模块,也可以使用其他应用程序的模块。可以让多个相互独立的应用沟通连通,灵活性更强。 4. 全局属性 Webpack4中不支持全局属性,使得在构建时,一些全局属性无法正常引用。Webpack5添加了对于全局属性的支持,可以让全局属性正常工作,而不会产生错误。 5. 缓存 针对于缓存方面,Webpack5在开发模式中开启持久化缓存,可以在增量构建时提供更快的编译速度,以避免重新运行整个Webpack构建流程。 综上所述,Webpack5对于性能、tree shaking、模块联邦,全局属性这些进行了大量的优化和改进,拥有更好的性能表现。而且Webpack5的一些新特性,如模块联邦,可以满足更多的需求,Webapck5相比Webpack4具有更好的发展前景和应用前景。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值