某些包比较大,比如echarts
,但是用到的页面实际上并不多,所以不能打包到common里面去,想在跳转到某个页面的时候,按需加载,这个怎么处理。
web pack本身只提供了一个require.ensure
,
require.ensure(['echarts'], function() {
var echarts = require('echarts');
/* ... */
});
但是这个代码有点丑陋,而且,总不能我所有使用到echarts
的页面都去写一遍吧。
请问有其他更优雅的方式吗?
现在工程里面就是js文件根据路由按需加载,然后每个使用echarts的页面都被打包进了一份echart。
但是首页等很多页面又没有使用这个,所以不想打包进common里面去;十几个用到echarts
的页面每个页面包含一份,有重复。
给你提供一个我目前实现按需加载的思路,使用async;此外可能webpack要2.x以上
点这里