javascript - 关于js简单模块加载器的问题
伊谢尔伦
伊谢尔伦 2017-04-11 12:10:15
[JavaScript讨论组]

书上看到的一段简易的模块加载器的示例代码,其中最关键的地方不能很好理解,求解答,代码如下:

let Module = (() => {
    let module_list = {};
    function define(name,rely,callback){
        if (module_list[name]){
            console.log("The module have already existed!")
        }else{
            for(let i = 0;i < rely.length;i++){
                rely[i] = module_list[rely[i]];
            }
            module_list[name] = callback.apply(callback,rely);//这个apply操作不是很明白
        }
    }

    function require(name){
        if (module_list[name]){
            return module_list[name]
        }else{
            console.log("There is no such module!")
        }
    }

    let api = {
        "define":define,
        "require":require
    };
    return api;
})();

以上代码,是我根据书上,仿写的,代码中apply那一句不是很明白,求解答

伊谢尔伦
伊谢尔伦

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

全部回复(2)
怪我咯

define 大概是这么用:

define('xxx', ['jquery', 'angular'], function($, angular) {
  // $ 和angular 变量直接可用,因为jquery和angular 导出的变量会传进去
})

分析代码可知某模块的逻辑都是写在callback里,然后把callback返回的结果赋值给module_list[name]的;接下来的目标就是把module_list['jquery']module_list['angular']传进callback。依赖数组是rely,所以这行代码的作用是把rely数组里的元素一个个传进callback调用的。看看apply的用法吧。

阿神

参考:MDN: Function.prototype.apply()

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

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