在前面的学习中咱们对于如何引入第三方类库(Jquery)推荐了两种方式,第一种是import引入的方式,第二种是ProvidePlugin插件。那两种引入方法有什么区别那?vue
import引入方法:引用后无论你在代码中使用不使用该类库,都会把该类库打包起来,这样有时就会让代码产生冗余。(引用即打包)jquery
ProvidePlugin引入方法:引用后只有在类库使用时,才按需进行打包,因此建议在工做使用插件的方式进行引入。 (按需打包)webpack
所以在平常开发中选用ProvidePlugin插件的方式进行打包,可在必定程度上减轻代码的冗余。web
抽离的第一步是修改入口文件,把我JQuery加入到入口文件中:npm
config/webpack.entry.js文件:数组
//声明entry变量 const entry={}; //声明路径属性 entry.path={ entry:'./src/entry.js', jquery:'jquery' //须要分离的文件 }; //进行模块化 module.exports=entry;
引入optimize优化插件,并进行相关配置,以下:ide
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文件变的很小。优化
在实际开发中,咱们会引用不止一个第三方类库,这时也须要抽离,这里咱们在引入Vue相关操做以下:
npm instawll vue --save
由于这个类库须要在生产环境中使用,故采用–save。
//声明entry变量 const entry={}; //声明路径属性 entry.path={ entry:'./src/entry.js', jquery:'jquery' , //须要分离的文件 vue:'vue' }; //进行模块化 module.exports=entry;
相比第一种只是多加了一个vue选项。
修改CommonsChunkPlugin配置
须要修改两个位置:
第一个是在name属性里把原来的字符串改成数组,由于咱们要引入多个模块,因此是数组;
第二个是在filename属性中把咱们输出的文件名改成匹配付[name],这项操做就是打包出来的名字跟随咱们打包前的模块。
修改代码以下:
new webpack.optimize.CommonsChunkPlugin({ //name对应入口文件中的名字,咱们起的是jQuery name:['jquery','vue'], //把文件打包到哪里,是一个路径 filename:"assets/js/[name].js", //最小打包的文件模块数,这里直接写2就好 minChunks:2 }),
webpack
配置完成后,咱们先删掉之前打包的dist目录,而后用webpack再次打包,你会发现jquery、vue被抽离了出来。