webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

栏目: JavaScript · 发布时间: 5年前

内容简介:上节:source-map上节目录如下:

目录

上节:source-map

上节目录如下:

webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

概念

官方:描述移除 JavaScript 上下文中的未引用代码。

也就是希望webpack在打包时把没用到的函数删掉,最常见的就算第三方函数库:lodash,date-fns等。

新建src/js/math.js:

export function add(...arg) {
  return arg.reduce((x, y) => x + y);
}

export function sub(...arg) {
  return arg.reduce((x, y) => x - y);
}

这里定义了两个函数,然后修改src/index.js:

import {add} from './js/math';

console.log(add(2, 4, 11));

修改webpack.config.js的mode选项,将production改为development:

// 省略
mode: 'development',
// 省略

这样打包后就不会压缩代码了

然后npm run build, 编辑器打开bundles/main.js,一直翻到最后:

webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

可以看到,虽然index.js里只用到了add方法,但webpack还是会把math.js中导出的方法都进行打包,那么tree shaking就是用来解决这个问题的。

开启tree shaking

在package.json里添加一个属性:

package.json:

// 省略
"sideEffects": false,
// 省略

sideEffects如果设为false,webpack就会认为所有没用到的函数都是没副作用的,即删了也没关系。

修改wbpack.config.js:

module.exports = {
  mode: 'development',
  entry: './src/index.js',
  output: {
    filename: '[name].js',
    path: resolve(__dirname, 'bundles')
  },

  // 开启devServer
  devServer: {},


  optimization: {
    // 优化导出的模块
    usedExports: true
  },

  module: {
    rules: [{
      test: /\.(gif|jpg|jpeg|png|svg)$/,
      use: ['url-loader']
    }, {
      test: /\.less$/,
      use: ['style-loader', 'css-loader', 'postcss-loader', 'less-loader']
    }]
  },
  plugins: [
    new HtmlWebpackPlugin({
      template: './index.html'
    }),
    new CleanWebpackPlugin()
  ]
};

然后npm run build, 打包bundles/main.js:

webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

这个注释表明webpack已识别出哪些方法是真正被用到的,但是继续看111行:

webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

这两个方法还在,说明这次打包只是标记出了用到的方法,tree shaking的效果并未生效,这是因为刚才的打包模式是develpoment, 在mode === develpoment的情况下,因为需要source-map调试,如果删掉代码,source-map的标记位置就不准确了,所以得在production模式下才能试tree shaking。

修改webpack.config.js:

module.exports = {
  mode: 'production',
  entry: './src/index.js',
  output: {
    filename: '[name].js',
    path: resolve(__dirname, 'bundles')
  },

  // 开启devServer
  devServer: {},


  // optimization: {
  //   // production模式下默认开启
  //   usedExports: true
  // },

  module: {
    rules: [{
      test: /\.(gif|jpg|jpeg|png|svg)$/,
      use: ['url-loader']
    }, {
      test: /\.less$/,
      use: ['style-loader', 'css-loader', 'postcss-loader', 'less-loader']
    }]
  },
  plugins: [
    new HtmlWebpackPlugin({
      template: './index.html'
    }),
    new CleanWebpackPlugin()
  ]
};

再次npm run build:

webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

代码被压缩了,我们可以ctrl + f搜索reduce 发现只有这个add方法,那个sub被去除了,这样tree shaking就生效了

注意事项

在实际的项目里,我们自己写的方法如果没用到,基本也不会有啥问题,但是第三方模块和样式就不好说了,比如在index.js中引入:

webpack4.29.x成神之路(十三) 摇树优化(tree shaking)

这种全局引入的方式,webpack依然会视为没用到的模块而被tree shaking掉,这些代码就是所谓的,有副作用的代码,我们要禁止对他们tree shaking.

修改package.json的sideEffects属性:

// 省略

"sideEffects": [
    // 数组里列出黑名单,禁止shaking下列代码
    "@babel/polly-fill",
    "*.less",

    // 其它有副作用的模块
    "./src/some-side-effectful-file.js"
  ],


//省略

这样tree shaking就不会误删代码了。

下节:区分开发和生产环境(待更新)


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

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

2小时品牌素养

2小时品牌素养

邓德隆 / 2009-1 / 38.00元

《2小时品牌素养(第2版)》第一次系统发布有关中国企业的品牌竞争力分析报告,揭示了中国一流企业在品牌战略上面临的深重危机,提出了定位突围之道和实践方法。全书分上下两篇,上篇详细分析了定位的原理,给出定位的三种方法,并特别为中国企业走向世界指出了三条出路;下篇以王老吉品牌战略历程为例,细致论述了一个品牌打造的完整过程,并就品牌实践中的许多关键问题进行了阐述和研讨。作为兼顾理论和实践的第2版,《2小时......一起来看看 《2小时品牌素养》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具