Webpack 5 混淆插件terser-webpack-plugin生命周期作用时机和使用注意事项

news/2025/1/16 1:54:06 标签: webpack, 前端, node.js

参考案例代码

海南酷森科技有限公司/webpack-simple-demo

Terser(简要的/简短的) 混淆依据

  1. 混淆是发生在代码已经 bundle 之后的事情

  2. 变量或者函数在被引用或赋值时才能被混淆

  3. 孤立的函数或者变量可能会被移除,但不会被混淆,要通过显式地引用

如果被赋值的变量没有被使用,会被移除,上图来看

打包后的代码,url 被干掉了

webpack 的 externals 配置(先于 terser)

  1. 该参数的意义,即保留现有的 import $ from 'jquery' 引用方式,又明确告知,这个 jquery 不需要打包到最终代码去,例如 import Vue from "vue",也即 Vue 这个变量目前可以作为模块方式被所有模块使用,但是这个 import Vue from "vue" 提取方式是从全局 cdn 链接获得,这样可以减少文件打包后的体积,这样说太抽象,我们看几个截图就一目了然了

webpack 开启外部依赖后的打包后的结果

  1. 先看源码,引入方式仍然 webpack 方式的引入,使用时也是模块化使用

  1. 打包后的代码,在顶部会直接用 o = jQuery的方式来获取,而不是从自身的模块中加载,就这么一点点区别,但是 var r = e.n(o);代码还是将 jQuery 注册为 webpack 中的模块了,后续代码都会用 r() 来获取这个对象,这样外部与内部就统一了

  1. webpack.config.js 中的设置,你可以改个名 JQ试试,打包时就变成了 JQ

  1. 这是不是就学会使用了

terser 之前的那个步骤是什么样子的?

  1. 先关闭 terser,打包出来的格式如下

  1. 结构是没啥变化的,terser 因为无引用不压缩的逻辑,JQ 这个属于根变量,没有任何引入渠道,所以不会进行任何处理,因此 terser 过程是发生在代码已经 bundle 出来后,再根据抽象语法树进行混淆压缩处理,而处理的关键就是是否是根变量,赋值变量都会被重命名,例如 external_JQ_namespaceObject这些,__webpack_require__,JQ 既不是赋值变量也不是导出变量,所以不会被重命名,不信我们下面给了一个案例

  1. 我随便写了一个 wx.runtime.getURL() 这是一个不存在的变量下的函数引用,它不会被处理

源代码,被赋值的变量会被重新命名,根变量不会

  1. 得出一个结论,任何根变量都可以放心大胆地使用,不会被混淆处理,在开发 chrome exension 时,我就担心 chrome.* 这种变量是否会被改名,现在结论就是不用担心这个概念,不会被改名,只要无赋值概念,都不存在混淆改名的问题,大胆使用


http://www.niftyadmin.cn/n/5824532.html

相关文章

vscode 扩展Cline、Continue的差别?

Cline和Continue都是VSCode的AI编程插件,它们在功能、用户体验、性能、适用场景以及配置和使用步骤等方面存在一些差别: 一、功能差异 编辑功能 Cline:能够分析项目的文件结构和源代码抽象语法树(AST),通…

// Error: line 1: XGen: Candidate guides have not been associated!

Maya xgen 报错// Error: line 1: XGen: Candidate guides have not been associated! 复制下面粘贴到Maya脚本管理器python运行: import maya.cmds as cmds def connect_xgen_guides():guide_nodes cmds.ls(typexgmMakeGuide)for node in guide_nodes:downstream…

docker 国内源

提供的docker 国内源 "registry-mirrors": [ "https://docker.m.daocloud.io" ]

LeetCode100之搜索二维矩阵(46)--Java

1.问题描述 给你一个满足下述两条属性的 m x n 整数矩阵: 每行中的整数从左到右按非严格递增顺序排列。每行的第一个整数大于前一行的最后一个整数。 给你一个整数 target ,如果 target 在矩阵中,返回 true ;否则,返回…

Unity-Mirror网络框架-从入门到精通之RigidbodyBenchmark示例

文章目录 前言示例代码逻辑测试结论性能影响因素最后前言 在现代游戏开发中,网络功能日益成为提升游戏体验的关键组成部分。本系列文章将为读者提供对Mirror网络框架的深入了解,涵盖从基础到高级的多个主题。Mirror是一个用于Unity的开源网络框架,专为多人游戏开发设计,它…

最优控制 (Optimal Control) 算法详解及案例分析

最优控制 (Optimal Control) 算法详解及案例分析 目录 最优控制 (Optimal Control) 算法详解及案例分析1. 引言2. 最优控制的基本概念2.1 最优控制的定义2.2 最优控制的核心思想2.3 最优控制的应用领域3. 最优控制的主要方法3.1 动态规划 (Dynamic Programming)3.2 庞特里亚金最…

TiDB之旅——TiFlash篇

作者: 有猫万事足 原文来源: https://tidb.net/blog/772a4767 前言 经过之前的4篇,其实总体的报表相应时间已经从小时级别到了分钟级,有新的报表需求,基本很快都能解决。 https://tidb.net/blog/f6bc5537 https…

Js:正则表达式及正则表达式方法

① 创建正则表达式对象: /** 语法:* var reg new RegExp(正则表达式, 匹配模式);* 匹配模式(字符串类型):i --> 忽略大小写 g --> 全局匹配模式*/var reg new RegExp(a, i);var str abc; /** 正则表达式的方法&#…