码迷,mamicode.com
首页 > Web开发 > 详细

JS模块函数

时间:2016-09-12 20:37:11      阅读:166      评论:0      收藏:0      [点我收藏+]

标签:

var MyModules = (function Manager() {
var modules={};
// 变量名 数组 回调函数
function define(name, deps, impl) {
for (var i=0; i<deps.length; i++) {
deps[i] = modules[deps[i]];
}
modules[name] = impl.apply( impl, deps );
//apply第一个参数和调用者一样,可以直接传null == modules[name] = impl.apply( null, deps );
}
function get(name) {
return modules[name];
}
return {
define: define, //设置modules的值
get: get //获得modules的值
};
})();

MyModules.define( "bar", [], function() {
function hello(who) {
return "Let me introduce: " + who;
}
return {
hello: hello
};
} );
//上面执行后等于改变了modules的值如下:
// modules = {
// "bar":{
// "hello":function hello(who) {
// return "Let me introduce: " + who;
// }
// }
// }

MyModules.define( "foo", ["bar"], function(bar) {
var hungry = "hippo";
function awesome() {
console.log( bar.hello( hungry ).toUpperCase() );
}
return {
awesome: awesome
};
} );
//上面执行后等于改变了modules的值如下:
// modules = {
// "foo":{
// "awesome":function(){
// console.log( { "hello":function hello(who) { return "Let me introduce: " + who;} }.hello( hungry ).toUpperCase() );
// }
// }
// }
var bar = MyModules.get( "bar" );
var foo = MyModules.get( "foo" );
console.log( bar.hello("hippo") ); // Let me introduce: hippo
foo.awesome(); // LET ME INTRODUCE: HIPPO

JS模块函数

标签:

原文地址:http://www.cnblogs.com/Jasonellen/p/5866085.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!