Page 70 - 你不知道的JavaScript(上卷)
P. 70

return {
                             define: define,
                             get: get
                         };
                     })();

                 这段代码的核心是 modules[name] = impl.apply(impl, deps)。为了模块的定义引入了包装
                 函数(可以传入任何依赖),并且将返回值,也就是模块的 API,储存在一个根据名字来管
                 理的模块列表中。

                 下面展示了如何使用它来定义模块:
                     MyModules.define( "bar", [], function() {
                         function hello(who) {
                             return "Let me introduce: " + who;
                         }

                         return {
                             hello: hello
                         };
                     } );

                     MyModules.define( "foo", ["bar"], function(bar) {
                         var hungry = "hippo";
       邮
                         function awesome() {
       电                     console.log( bar.hello( hungry ).toUpperCase() );
                         }

                         return {
                             awesome: awesome
                         };
                     } );

                     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

                 "foo" 和 "bar" 模块都是通过一个返回公共 API 的函数来定义的。"foo" 甚至接受 "bar" 的
                 示例作为依赖参数,并能相应地使用它。

                 为我们自己着想,应该多花一点时间来研究这些示例代码并完全理解闭包的作用吧。最重
                 要的是要理解模块管理器没有任何特殊的“魔力”。它们符合前面列出的模块模式的两个
                 特点:为函数定义引入包装函数,并保证它的返回值和模块的 API 保持一致。

                 换句话说,模块就是模块,即使在它们外层加上一个友好的包装工具也不会发生任何变化。

                                                                            作用域闭包   |   55
   65   66   67   68   69   70   71   72   73   74   75