javascript - require.ensuire 第一个参数空或者不空有什么关系?
伊谢尔伦
伊谢尔伦 2017-04-11 12:35:43
[JavaScript讨论组]

1.

require.ensure([
'./a'
],function(){

    var a  = require('./a') 
    

})

2.

上面的依赖有必要引入么?反正这里还是要 require,它还不如下面这样

require.ensure([
'./a'
],function(a){

   // 在这里用到 a, 不需要再 require
    

})

3.

还有另外一个种用法

require.ensure([

],function(){

    var a = require('./a');

})

文档只是说如果加入参数, callback 会在依赖加载后在执行

但是打包后发现无论是 1 还是 3, a 都会被打包到 chunk 中(有无依赖).

那么这个第一个参数:依赖加不加入有什么影响?

13 哪个是同步?哪个是异步?

伊谢尔伦
伊谢尔伦

小伙看你根骨奇佳,潜力无限,来学PHP伐。

全部回复(1)
黄舟

require.ensure都是commonjs异步加载, 不存在你说的哪个同步哪个异步

分为二种情况使用:

情况一:

require.ensure([], function(require){
    require('./a.js');
});

此时会单独打包出一个js文件,没有自定义名称的话,会被命名为1.js(有hash时候会带上md5)

情况二:

require.ensure(['./a.js'], function(require) {
    require('./b.js');
});

1、此时a.js作为依赖被加载,但是没有被执行(官方文档说的only loads the modules)
2、a.js和b.js会被打包成一个文件。
3、回调函数里只require了b.js,只有b.js的内容会被执行。
4、如果你需要使用a.js的内容,需要再加上require('./a.js')


最后require.ensure主要是为了区别require-AMD的写法

require(["./a.js"], function(a) {
    var b = require("./b.js");

});

在AMD的模式中,[]里的内容a会被先下载并立即执行,再接着执行回调函数的内容b

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号