本节用开发环境
做代码的打包
也就是运行npm run dev
但是如果用webpack-dev-server
启动一个服务器的话
我们就看不到打包生成的内容了
为了方便能看到开发环境打包生成的文件的形式
再创建一个命令dev-build,
实际上它就是用dev环境的配置文件, 帮我们做了一次打包生成一个dist目录
运行npm run dev-build
build目录下正常的话是放配置文件的
现在多了dist目录
打包生成的dist目录并不在lesson根目录下
这是什么原因呢,
其实是因为我们把webpack的配置
项放到了build目录下,在打包的过程中,
使用的一些配置项,没有进行同步的变更,
这就会导致打包生成的文件就放到了build目录下
解决这个问题
1.修改webpack.common.js
里output
的配置,
其中path
表示的是打包生成的文件存放的位置,
__dirname
表示的是webpack.common.js
这个文件的绝对路径,
在这里是lesson/build
,
'dist'
表示的是打包生成的文件存放到跟webpack.common.js
这个文件同级的dist
目录下
2.目标是打包生成的文件要放到lesson
目录下dist
目录下,
webpack.common.js
现在在build目录下,
打包文件应该放在build目录上一层级的目录下面,
也就是lesson目录下对应的dist目录下,
所以我们需要修改为下边这样
3.CleanWebpackPlugin
3.png 4.png
4.然后npm run dev-build,
就会发现打包生成的文件已经存放到lesson
目录下的dist
目录里了
Code Splitting 代码分割
1.安装一个第三方的包
npm insatll lodssh --save-dev
2.修改src下的index.js
代码,
它引入一个库,
使用这个库做了一个字符串连接这样一个操作
3.然后我们运行打包命令
npm run dev-build
,打包成功,
打开dist目录下的index.html
open in broser
代码正常运行
image
4.dist目录下有main.js,
也就是打包的过程中,
lodash工具库以及src下的index.js中的业务代码,
都被打包到了一个文件中,
假如我们引入的第三方库 loadsh有1M,
而我们的业务代码很多也有1M,
那么当我们打包之后生产的main.js就有2M(不压缩的情况下)。
如果用户访问index.html这个文件,想输出我们的业务逻辑的话,
就要先加载一个2M的js文件,它要等到加载完成才会去执行业务里面的逻辑
才会去把页面展示出来
通常情况下,第三方库代码是不会变的,
而我们的业务代码却经常会变化,
改变业务逻辑,
重新打包,
用户如果想要获得最新的内容就要重新去加载2M的内容
带来的问题:
1.打包文件过大,加载时间长的问题
2.代码变更,用户需要重新加载
代码分割(自己配置)
1.在src目录下,再创建一个文件lodash.js,把loadsh的引入放在这个文件里/lodash这个文件就是加载了lodash
把lodash挂载到了全局的window上
这样在控制台,获取其他地方就可以直接使用下划线这个变量了
2.index.js只写业务逻辑就可以了
1.png- 然后我们修改下webpack的入口文件,原来我们的入口文件只有一个,现在新增一个
4.然后再运行打包npm run dev-build
,会发现dist
目录下生成了 lodash.js
和main.js
两个文件,并且dist
目录下的index.html
里也引入了这两个文件
浏览器打开index.html 也可以正常运行,
通过这种方式,我们把打包生成的main.js从2M拆分成了两个1M的文件,
这个时候用户访问页面,就不需要加载2M的内容了,
而是加载两个1M的内容,
大家知道浏览器可以并行的加载文件,
大量的实践证明,
同时加载2个1M的内容可能比加载一个2M的内容要稍微快一点。(不是绝对的)
当我们修改了业务代码index.js ,
如果第一种方式,
都打包到一个main.js里的这种方式,
用户访问代码生成的内容时,需要重新加载2M的内容,
如果是我们拆分后的方式,因为lodash是没有变化的,
用户访问的时候,直接从浏览器缓存就可以获取,
用户只需要重新加载新的生成的main.js 就可以了,也就是说用户只加载了1M的内容
所以第二种方式,可以有效的提升我们页面展示的速度
所以,
在一些项目中,
我们会通过对代码公用部分进行拆分,
来提升项目运行的速度,这种代码的拆分就是Code Splitting
没有Code Splitting也没有任何问题,
代码也可以正常运行,
但是有了Code Splitting通过对代码的拆分,
就可以让我们的代行执行的性能更高一些,
用户体验更好一些
在没有webpack之前,
我们通过自己对代码的拆分,
也可以有效的提升代码的性能,
所以Code Splitting本质上是和webpack没有任何关系的,
但是现在webpack也有一些插件,
可以很方便的帮我们实现Code Splitting也就是代码分割这样的功能。
在webpack4里面,插件splitChunksolugin直接就和webpack做了捆绑,
不用安装,直接可以用
代码分割(使用webpack插件--同步)
1.删除我们刚才写的lodash.js
文件,
把lodash
的引入,
还放入index.js
里,
然后再把entry
还改为一个入口文件
2.配置一下
webpack.common.js
image
3.打包,就可以看到dist
目录下,
除了main.js
外,
还多了一个vendors~main.js
;
其中main.js
有index.js
的业务逻辑,
但是并没有lodash
;而vendors~main.js
里是把 lodash
单独提取出来了
也就是说,之前我们需要手动的去做分隔,
而现在我们通过一个简单的`webpack`配置,
webpack自己就知道了,
当遇到这种`公用的类库的时候`,
就会自动的帮我们把这个类库打包生成一个文件,
把我们的业务逻辑再拆分成一个文件,
自动的帮我们实现了 `Code Splitting`,
这就是为什么我们经常说`webpack`中的`Code Splitting`
代码分割(使用webpack插件--异步)
1.src目录下index.js
import _ from 'lodash';
console.log(_.join(['a', 'b', 'c'], '***'))
console.log(_.join(['a','d','e'],'***'))
我们原来的index.js里的代码是这样的,
先引入lodash这个库,
然后再调用库里的方法,
它是一个`同步的执行顺序,先去加载模块,然后再接着往下执行`。
处理这种同步的逻辑,webpack借助刚才的配置,
它会去分析,
什么样的模块该给它打包生成一个单独的文件,
来做代码分隔。
实际上,我们除了同步的引入一些模块之外,
还可以去做异步模块的引入,我们先改下index.js文件
// 同步
// import _ from 'lodash';
// console.log(_.join(['a', 'b', 'c'], '***'))
// console.log(_.join(['a','d','e'],'***'))
// 异步
//一开始这个JS文件里并没有lodash这个库,而是通过JSONP的形式去获取lodash这个库的代码,
//然后获取完之后,then方法会执行,我们引入的lodash这个库,会被放到下划线_这个变量里
function getComponent() {
return import('lodash').then(({default:_}) => {
var element = document.createElement('div');
element.innerHTML = _.join(['LEE', 'YANG'], '-');
return element
})
}
//上边,我们定义了一个函数getComponent,这个函数会 异步的加载lodash这个库,
//当加载成功后,它会创建一个div标签,内容是LEE-YANG,然后把div标签返回出来
//执行函数getComponent,这个函数返回的是一个import,而import返回的是一个promise,
//promise里接受的就是返回的element,获取到element之后,把element挂载到body上
getComponent().then(element => {
document.body.appendChild(element)
})
2.执行打包,会发现生成的文件里,
除了main.js
还多出一个0.js
,main.js
是代码分割出的业务逻辑,
0.js
里就是分割出的lodash
的代码,
也就是说,异步加载
的代码,webpack
也会做代码的分割
所以,webpack的代码分割,有两种方式。
1.借助webpack里的配置,
去编写我们的同步的代码,这个配置,
结合同步代码,它会去分析我们同步代码里的内容,从而做代码分割
optimization: {
splitChunks: {
chunks:'all'
}
},
2. 即便我们不做optimization的配置,
我们写异步载入组件代码,
那么异步载入的组件,
也会自动的被打包到一个单独的文件里,
这也是另外一种形式的代码分割。
总结:
Code Splitting和webpack无关,
它是一个单独的概念,
用来提升整个项目的性能
webpack实现代码分割两种方式;
第一,同步代码,做optimization的配置实现代码分割;
第二,异步代码,无需做任何配置,打包时会自动进行代码分割
网友评论