当前位置: 移动技术网 > IT编程>开发语言>JavaScript > 模块加载原理(第二种)

模块加载原理(第二种)

2019年11月18日  | 移动技术网IT编程  | 我要评论
var kmodule = (function(){
    var modules = {}
    ,config = {}
    ,define = function(deps,factory){
        typeof deps == 'function' && (
            factory = deps,
            deps = []
        )
        if(!array.isarray(deps)){
            deps = [deps];
        }
        var exports = function(name,impl){
            if(!modules[name]){
                kmodule[name] = modules[name] = impl;
            }
        }
        typeof factory == 'function' && factory.apply(factory,[exports])
    }
    
    ,require = function(deps,handle){
        typeof deps == 'function' && (
            handle = deps,
            deps = []
        )
        if(!array.isarray(deps)){
            deps = [deps];
        }
        for(let i = 0; i < deps.length; i++){
            deps[i] = modules[deps[i]]
        }
        handle.apply(handle,deps);
    }
    
    return {
        define:define,
        require:require,
    };
    
})();


kmodule.define(function(exports){
    var inittable = function(){
        return "初始化表格模块";
    }
    var tableimpl = {
        inittable:inittable
    }
    exports('table',tableimpl)
});

//第一种调用方式
kmodule.require('table',function(){
    var table = kmodule.table
    alert(table.inittable());
});
//第二种调用方式
kmodule.require('table',function(table){
    alert(table.inittable());
});

 

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网