(21/24) webpack实战技巧:webpack对三方类库的优化操作

作者 : 开心源码 本文共1656个字,预计阅读时间需要5分钟 发布时间: 2022-05-12 共156人阅读

1.优化第一步–选用引入方式

在前面的学习中我们对于如何引入第三方类库(jquery)推荐了两种方式,第一种是import引入的方式,第二种是ProvidePlugin插件。那两种引入方法有什么区别那?
import引入方法:引用后不论你在代码中使用不使用该类库,都会把该类库打包起来,这样有时就会让代码产生冗余。(引用即打包)
ProvidePlugin引入方法:引用后只有在类库使用时,才按需进行打包,所以建议在工作使用插件的方式进行引入。 (按需打包)
因而在日常开发中选用ProvidePlugin插件的方式进行打包,可在肯定程度上减轻代码的冗余。

2.优化第二步–三方类库分离

2.1 单个三方类库分离

2.1.1 第一步:修改入口文件

抽离的第一步是修改入口文件,把我jquery加入到入口文件中:
config/webpack.entry.js文件:

//公告entry变量const entry={};//公告路径属性entry.path={    entry:'./src/entry.js',    jquery:'jquery'  //需要分离的文件};//进行板块化module.exports=entry;

2.1.2 第二步:引入插件

引入optimize优化插件,并进行相关配置,如下:

new webpack.optimize.CommonsChunkPlugin({    //name对应入口文件中的名字,我们起的是jquery    name:'jquery',    //把文件打包到哪里,是一个路径    filename:"assets/js/jquery.min.js",    //最小打包的文件板块数,这里直接写2就好    minChunks:2}),

minChunks一般都是固定配置,但是不写是不行的,你会打包失败。
filename是可以省略的,这是直接打包到了打包根目录下,我们这里直接打包到了dist文件夹下的assets/js/下。
配置完成后,我们先删掉以前打包的dist目录,而后用webpack再次打包,你会发现jquery被抽离了出来,并且我们的entry.js文件变的很小。

分离前.png分离后.png

2.2 多个第三方类库抽离

在实际开发中,我们会引用不止一个第三方类库,这时也需要抽离,这里我们在引入 Vue相关操作如下:

2.2.1 安装Vue

npm instawll vue --save

由于这个类库需要在生产环境中使用,故采用–save

2.2.2 修改入口文件

//公告entry变量const entry={};//公告路径属性entry.path={    entry:'./src/entry.js',    jquery:'jquery' , //需要分离的文件     vue:'vue'};//进行板块化module.exports=entry;

相比第一种只是多加了一个vue选项。

image.png

2.2.3 修改插件配置

修改CommonsChunkPlugin配置
需要修改两个位置:

  1. 第一个是在name属性里把原来的字符串改为数组,由于我们要引入多个板块,所以是数组;
  2. 第二个是在filename属性中把我们输出的文件名改为匹配付[name],这项操作就是打包出来的名字跟随我们打包前的板块。
    修改代码如下:
new webpack.optimize.CommonsChunkPlugin({    //name对应入口文件中的名字,我们起的是jQuery    name:['jquery','vue'],    //把文件打包到哪里,是一个路径    filename:"assets/js/[name].js",    //最小打包的文件板块数,这里直接写2就好    minChunks:2}),

image.png

2.2.4 打包

webpack

配置完成后,我们先删掉以前打包的dist目录,而后用webpack再次打包,你会发现jqueryvue被抽离了出来。

分离后.png分离后文件.png

总结:
在项目开发中,我们很使用很多第三方类库,那好的做法就是把第三方这些类库一律抽离解决,这样在项目维护和性能上都是不错的选择。

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » (21/24) webpack实战技巧:webpack对三方类库的优化操作

发表回复