首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >更广泛的破坏-webpack插件?

更广泛的破坏-webpack插件?
EN

Stack Overflow用户
提问于 2019-02-13 00:20:34
回答 1查看 4.5K关注 0票数 1

有没有办法彻底破坏与vue捆绑在一起的webpack组件?

当通过terser-webpack-pluginmangle.properties设置为true应用损坏时,并不是所有的属性名称都会损坏,例如:

代码语言:javascript
复制
location: {
  lng: -.134281,
  lat:51.513508,
  zoom:13,
  pitch:1,
  bearing:60
}

变成了

代码语言:javascript
复制
location:{
  k:-.134281,
  M:51.513508,
  zoom:13,
  pitch:1,
  V:60
}

编辑

根据请求: Webpack配置文件的相关部分,在本例中默认的vie-cli配置与mangle.properties项手动添加:

代码语言:javascript
复制
minimizer: [
      {
        options: {
          test: /\.m?js(\?.*)?$/i,
          chunkFilter: () => true,
          warningsFilter: () => true,
          extractComments: false,
          sourceMap: false,
          cache: true,
          cacheKeys: defaultCacheKeys => defaultCacheKeys,
          parallel: true,
          include: undefined,
          exclude: undefined,
          minify: undefined,
          terserOptions: {
            output: {
              comments: /^\**!|@preserve|@license|@cc_on/i
            },
            compress: {
              arrows: false,
              collapse_vars: false,
              comparisons: false,
              computed_props: false,
              hoist_funs: false,
              hoist_props: false,
              hoist_vars: false,
              inline: false,
              loops: false,
              negate_iife: false,
              properties: false,
              reduce_funcs: false,
              reduce_vars: false,
              switches: false,
              toplevel: false,
              typeofs: false,
              booleans: true,
              if_return: true,
              sequences: true,
              unused: true,
              conditionals: true,
              dead_code: true,
              evaluate: true
            },
            mangle: {
              safari10: true,
              properties: true
            }
          }
        }
      }
    ],
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-02-13 02:19:54

这两个属性(zoompitch)恰好包含在reserved名称列表中,请查看UglifyJS在损坏期间内部使用的默认domprops.json文件。

tools/domprops.json中提供了一个默认的排除文件,它应该涵盖在各种浏览器中定义的大多数标准JS和DOM属性。传递--mangle-props domprops以禁用此功能

如果您希望保留此默认列表,则可以在插件的自定义小型化选项中执行以下任何操作:

  1. 创建自定义保留名称列表,
  2. 加载默认列表(domprops.json)并传入一个函数/筛选器,用于删除这些不需要的名称,
  3. 如果您确定没有名称冲突,只需合并这两个文件即可。

webpack.config.js

代码语言:javascript
复制
{
  optimization: {
    minimizer: [
      new TerserPlugin({
        minify(file, sourceMap) {
          const uglifyJsOptions = {
            mangle: {
              properties: {
                reserved: require('your_custom_list')
              }

              // Or filter them

              properties: {
                reserved: require('uglify-js/tools/domprops.json')
                  .filter(name => ![
                    'zoom',
                    'pitch'
                  ]
                  .includes(name))
              }
            }
          };

          return require('uglify-js').minify(file, uglifyJsOptions);
        },
      }),
    ],
  },
}

此外,在执行此操作时,请注意mangle.reservedmangle.properties.reserved之间的相似之处,因为后者可能是您在这里所需要的。看看小型化期权结构

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54660674

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档