javascript模块模式支持相互依赖

时间:2011-01-20 16:24:45

标签: javascript design-patterns

似乎使用以下javascript模块模式,不可能有相互依赖的模块:

var AA = (function(module, BB){
  module.sayHello = function(){
    alert("AA: hello!");
  };
  module.pokeYourFriend = function(){
    BB.sayHello();
  };
  return module;
})(AA || {}, BB);

var BB = (function(module, AA){
  module.sayHello = function(){
    alert("BB: hello!");
  };
  module.pokeYourFriend = function(){
    AA.sayHello();
  };
  return module;
})(BB || {}, AA);


> AA.pokeYourFriend();
*TypeError: Cannot call method 'sayHello' of undefined*

上述操作失败,因为在创建AA时BB不存在。

是否有允许这种情况的模式,或者是否应禁止相互依赖?

1 个答案:

答案 0 :(得分:2)

AABB的RHS值是函数表达式,它们以自上而下的顺序计算(这是Javascript中的正常顺序)。因此,在定义BB之前,您无法使用BB

您可以使用“构造函数”来创建这些模块并为其指定名称(“AA”或“BB”),而不是自行调用:

var create = (function(name) {
   var _friend = null;
   var _name = name;

   return {
      sayHello: function() {
         alert(_name + ": hello!");
      },
      pokeYourFriend: function() {
         if(_friend != null) {
            _friend.sayHello();
         }
      },
      setFriend: function(friend) {
         _friend = friend;
      }
   };
});

var AA = create("AA");
var BB = create("BB");

AA.setFriend(BB);
BB.setFriend(AA);

AA.pokeYourFriend(); //alerts "BB: hello!"
BB.pokeYourFriend(); //alerts "AA: hello!"