最近在看webpack的文档,在代码分割code splitting
这一章节有点疑惑。
http://webpack.github.io/docs...
关于require.ensure
,文档里说:
这里的evaluate怎么理解呢,是指的执行吗?但webpack打包文件本来就不会去执行文件的js代码,所以想请教下,require.ensure
以及require.include
除了会有分割点,其他的策略和正常的require
有什么不同吗?
最近在看webpack的文档,在代码分割code splitting
这一章节有点疑惑。
http://webpack.github.io/docs...
关于require.ensure
,文档里说:
这里的evaluate怎么理解呢,是指的执行吗?但webpack打包文件本来就不会去执行文件的js代码,所以想请教下,require.ensure
以及require.include
除了会有分割点,其他的策略和正常的require
有什么不同吗?
10 回答11.2k 阅读
5 回答4.8k 阅读✓ 已解决
4 回答3.1k 阅读✓ 已解决
2 回答2.8k 阅读✓ 已解决
3 回答2.3k 阅读✓ 已解决
3 回答2.2k 阅读✓ 已解决
2 回答2.6k 阅读✓ 已解决
require.ensure举例:
commonjs规范
上面的例子中,执行到这句代码时,mod,js会被浏览器下载(预加载),也就是上面英文写的only loads the modules,但是这个mod.js的内容不会被立即执行(懒执行),也就是上面说的it doesn't evaluate them
require.include
这个是webpack自带的,没有任何规范
它实现的功能和ensure一样,省去了让你在数组[]里写上模块名称的麻烦
最后你还可以使用AMD规范的写法
最后扯一下AMD和require.ensure的区别
require.ensure
模块被下载来后【不立即执行】,接着执行回调函数内容。AMD
模块被下载来【并且模块被执行完后】,再接着执行回调函数内容。