把你的devtools从webpack里删除

栏目: 编程工具 · 发布时间: 5年前

内容简介:通过判断是否为 dev 环境,加载生产环境是没有如果你

通过判断是否为 dev 环境,加载 vConsole 并实例化使用:

// 开发时引入 vConsole
if (process.env.NODE_ENV === 'development') {
  // 吐槽一波:不支持 import 方式
  const VConsole = require('vconsole');
  new VConsole();
}
复制代码

生产环境是没有 vConsole 了吧!想象很丰满,打包很骨感。

如果你 splitChunks 了的话,打包后的文件多出了个 vConsole ,约 90k。使用 webpack-bundle-analyzer 分析也会看到多出一大块。。。

在这个移动端分秒必争的时代,凡是能从代码层面上优化的没理由不做。

> 每次合并到主分支时注释再提交,像下面这样[笑哭]

// 开发时引入 vConsole
// if (process.env.NODE_ENV === 'development') {
//   // 吐槽一波:不支持 import 方式
//   const VConsole = require('vconsole');
//   new VConsole();
// }

> 每次开发时再去掉注释,丢你煤泥~
复制代码

码·格瓦拉:“优化是不可能不优化的,这辈子都不可能不优化的。”

定义浏览器端环境变量

启动时 NODE_ENV=development webapck 这样定义的环境变量只在 node 执行 webpack 时生效,通过 process.env 访问。简而言之,只能在 webpack.config.js 中判断 dev/prod。

所以实现之前的代码逻辑我们需要 DefinePlugin 。使用时:

// webpack.config.js
const webpack = require('webpack');

module.exports ={
  plugins: [
    new webpack.DefinePlugin({
      __DEV__: JSON.stringify(false),
    }),
  ],
};
复制代码

引入 vConsole 的方式基本不变:

// index.js
// __DEV__ 就是 DefinePlugin 注入的全局常量
// 开发时引入 vConsole
if (__DEV__) {
  // 吐槽一波:不支持 import 方式
  const VConsole = require('vconsole');
  new VConsole();
}

// 打包后的代码长这样:
// 看起来这插件就是执行文本替换的功能
if (false) {
  // 吐槽一波:不支持 import 方式
  const VConsole = require('vconsole');
  new VConsole();
}
复制代码

代码逻辑实现了,但是 vConsole 依旧在打包文件里。这时候就要借助我们功能强大的代码压缩。

代码压缩

webpack v4 版本设置为 mode: 'production' 后默认即启用代码压缩。

以前推荐的是 UglifyjsWebpackPlugin ,底层 uglify-js ,但是只支持 ES5,所以仓库上还有个 harmony 分支用来处理 ES6,webpack 插件用的也是这个分支。但是这个分支已经长时间没人维护了,所以官方转到另一个 TerserWebpackPlugin ,两个插件基本一模一样。

手动启用:

module.exports = {
  optimization: {
    minimize: true
  },
};

// 或者直接覆盖自带的,可进行颗粒度的控制
const TerserWebpackPlugin = require('terser-webpack-plugin');

module.exports = {
  optimization: {
    minimizer: [
      new TerserWebpackPlugin({
        terserOptions: {
          compress: {
            dead_code: true, // 默认。删除不可到达的代码
          },
        },
      });
    ],
  },
};
复制代码

而我们需要的就是其删除 dead code 功能,类似下面这样的就是 dead code:

----------------------------
| if (false) alert('你好'); | // 一块 dead code
----------------------------
复制代码

实际使用可能需要进行判断,但是有点坑。

statement dead_code 支持
true / false
1 === 2
'a' !== 'a'
'a' !== 'b'
undefined / null
  1. Boolean/Number 支持可写表达式判断
  2. String 只支持完全相同的两字符串判断,不同字符串 不支持
  3. Undefined/Null 不支持

最后

使用 DefinePlugin + TerserWebpackPlugin 配置,打包后发现 vConsole 没了。可以向老板申请加鸡腿了······

小贴士: ProvidePluginexternals 的区别,前者自动 import ,后者是无需 npm install 即可直接 import


以上所述就是小编给大家介绍的《把你的devtools从webpack里删除》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

内容创业:内容、分发、赢利新模式

内容创业:内容、分发、赢利新模式

张贵泉、张洵瑒 / 电子工业出版社 / 2018-6 / 49

越来越多的内容平台、行业巨头、资本纷纷加入内容分发的战争中,竞争非常激烈。优质的原创性内容将成为行业中最宝贵的资源。在这样的行业形势下,如何把内容创业做好?如何提高自身竞争力?如何在这场战争中武装自己?是每一位内容创业者都应该认真考虑的问题。 《内容创业:内容、分发、赢利新模式》旨在帮助内容创业者解决这些问题,为想要进入内容行业的创业者出谋划策,手把手教大家如何更好地进行内容创业,获得更高的......一起来看看 《内容创业:内容、分发、赢利新模式》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

SHA 加密
SHA 加密

SHA 加密工具

html转js在线工具
html转js在线工具

html转js在线工具