webpack压缩js代码示例:移除console debug 删除注释 保留函数名 并行压缩 移除指定函数

Webpack 默认的压缩配置(即使用内置的 TerserPlugin)通常包括类似 terserOptions 中的一些基本设置,但可能不会涵盖所有可用的 Terser 选项。默认的压缩通常会移除未使用的代码(tree shaking)、删除注释、缩短变量名(混淆)、删除不必要的空白和换行符等。

Webpack 默认配置可能不包含 drop_console、drop_debugger、pure_funcs、mangle 等高级选项的显式设置。这些选项需要你在自定义的 TerserPlugin 配置中明确指定。

对于 parallel 和 extractComments 选项,Webpack 默认的 TerserPlugin 配置也不会包含这些设置。如果你想要使用这些功能,你需要像你在示例代码中那样明确添加 TerserPlugin 并配置这些选项。

terser-webpack-plugin压缩代码实现的功能如下,

// webpack.config.js

const TerserPlugin = require('terser-webpack-plugin')
module.exports = {
    entry: './src/index.js',
    output: {
        filename: 'main.js',
    },
    mode: 'production',
    devtool: 'source-map', // 启动源映射(默认为false)
    optimization: {
        minimizer: [
            new TerserPlugin({
                terserOptions: {
                    // 压缩选项
                    compress: {
                        drop_console: true, // 移除console
                        drop_debugger: true, // 移除断点功能
                        pure_funcs: ['console.log'], // 移除指定函数
                    },
                    // 输出选项
                    output: {
                        // comments: false, // 删除所有注释
                        beautify: false, // 不美化输出(默认)
                    },
                    // 混淆选项, 默认会替换所有变量名,通过该选项控制替换变量名
                    mangle: {
                        properties: true, // 替换对象属性名
                        keep_classnames: true, // 保留类名
                        keep_fnames: true, // 保留函数名
                    },
                   
                },
                parallel: true, // 并行压缩,提高构建效率, // 尝试自动检测 CPU 核心数量   parallel: 4, // 指定 4 个 worker 进程  
                extractComments: false, // 提取注释到单独文件
            })
        ]
    }
}
// src/index.js
let a = 1;

//TEST
a+=1
console.log(a)

相关推荐

  1. js子元素

    2024-05-14 11:16:03       7 阅读
  2. 元素

    2024-05-14 11:16:03       22 阅读
  3. 27. 元素

    2024-05-14 11:16:03       31 阅读
  4. 27.元素

    2024-05-14 11:16:03       32 阅读
  5. conda环境

    2024-05-14 11:16:03       30 阅读
  6. 元素(简单)

    2024-05-14 11:16:03       31 阅读
  7. 元素

    2024-05-14 11:16:03       25 阅读

最近更新

  1. .Net Core WebAPI参数的传递方式

    2024-05-14 11:16:03       0 阅读
  2. QT--气泡框的实现

    2024-05-14 11:16:03       0 阅读
  3. LeetCode 968.监控二叉树 (hard)

    2024-05-14 11:16:03       0 阅读
  4. leetcode热题100.完全平方数(动态规划进阶)

    2024-05-14 11:16:03       0 阅读
  5. leetcode328-Odd Even Linked List

    2024-05-14 11:16:03       0 阅读
  6. C 语言设计模式(结构型)

    2024-05-14 11:16:03       0 阅读
  7. v-if 与 v-show(vue3条件渲染)

    2024-05-14 11:16:03       0 阅读
  8. kafka防止消息丢失配置

    2024-05-14 11:16:03       0 阅读

热门阅读

  1. 蓝桥杯-移动距离(最简单的写法)

    2024-05-14 11:16:03       5 阅读
  2. 你眼中的IT行业现状与未来趋势

    2024-05-14 11:16:03       2 阅读
  3. 谈谈std::map的lower_bound

    2024-05-14 11:16:03       3 阅读
  4. Linux-vi/vim

    2024-05-14 11:16:03       4 阅读
  5. CentOS常见的命令

    2024-05-14 11:16:03       2 阅读
  6. 水利行业工程设计资质如何去申请

    2024-05-14 11:16:03       5 阅读
  7. vue预览PDF文件的方法

    2024-05-14 11:16:03       4 阅读
  8. Flink Stream API实践

    2024-05-14 11:16:03       3 阅读