webpack代码分离精华(转载)

webpack ensure相信大家都听过。有人称它为异步加载,也有人说做代码切割,那这
个家伙到底是用来干嘛的?其实说白了,它就是把js模块给独立导出一个.js文件的,然后使用这个
模块的时候,webpack会构造script dom元素,由浏览器发起异步请求这个js文件。
场景分析:

比如应用的首页里面有个按钮,点击后可以打开某个地图。打开地图的话就要利用百度地图的js,于是
我们不得不在首页中把百度地图的js一起打包进去首页,一个百度地图的js文件是非常大的,假设为1m,于是就造成了我们首页打包的js非常大,用户打开首页的时间就比较长了。
有没有什么好的解决方法呢?

解决1

既然打包成同一个js非常大的话,那么我们完全可以把百度地图js分类出去,利用浏览器的并发请求
js文件处理,这样的话,会比加载一个js文件时间小得多。嗯,这也是个不错的方案。为baidumap.js
配置一个新的入口就行了,这样就能打包成两个js文件,都插入html即可(如果baidumap.js被多个
入口文件引用的话,也可以不用将其设置为入口文件,而且直接利用CommonsChunkPlugin,导出到一个
公共模块即可)可以参考我之前文章
webpack模块打包
那还有没有更好的解决方案呢?
解决2

当然还是有的!我们细想,百度地图是用户点击了才弹出来的,也就是说,这个功能是可选的。那么解决
方案就来了,能不能在用户点击的时候,我在去下载百度地图的js.当然可以。那如何实现用户点击的时候
再去下载百度地图的js呢?于是,我们可以写一个按钮的监听器

mapBtn.click(function() {
//获取 文档head对象
var head = document.getElementsByTagName(‘head’)[0];
//构建 script
var script = document.createElement(‘script’);
//设置src属性
script.async = true;
script.src = “http://map.baidu.com/.js
//加入到head对象中
head.appendChild(script);
})
上面的几行代码对大家来说都不难。可以在点击的时候,才加载百度地图,等百度地图加载完成后,在
利用百度地图的对象去执行我们的操作。ok,讲到这里webpack.ensure的原理也就讲了一大半了。
它就是 把一些js模块给独立出一个个js文件,然后需要用到的时候,在创建一个script对象,加入
到document.head对象中即可,浏览器会自动帮我们发起请求,去请求这个js文件,在写个回调,去
定义得到这个js文件后,需要做什么业务逻辑操作。
ok,那么我们就利用webpack的api去帮我们完成这样一件事情。点击后才进行异步加载百度地图js,上面
的click加载js时我们自己写的,webpack可以轻松帮我们搞定这样的事情,而不用我们手写
mapBtn.click(function() {
require.ensure([], function() {
var baidumap = require(‘./baidumap.js’) //baidumap.js放在我们当前目录下
})
})
搞定!当然还是分析一下。require.ensure这个函数是一个代码分离的分割线,表示 回调里面的require
是我们想要进行分割出去的,即require(’./baidumap.js’),把baidumap.js分割出去,形成一个
webpack打包的单独js文件。
文章来源:webpack代码分离
源码地址 webpack代码分离源码地址webpa_ensure

猜你喜欢

转载自blog.csdn.net/weixin_42727360/article/details/82146982