javascript - 如何动态地将观察者方法添加到 Ember.js 对象

标签 javascript coffeescript ember.js

所以我正在尝试将这些观察者方法动态添加到 Ember.js 对象

holderStandoutCheckedChanged: (->
    if @get("controller.parent.isLoaded")
        @get("controller").toggleParentStandout(@get("standoutHolderChecked"))
).observes("standoutHolderChecked")

holderPaddingCheckedChanged: (->
    if @get("controller.parent.isLoaded")
        @get("controller").toggleParentPadding(@get("holderPaddingChecked"))
).observes("holderPaddingChecked")

holderMarginCheckedChanged: (->
    if @get("controller.parent.isLoaded")
        @get("controller").toggleParentMargin(@get("holderMarginChecked"))
).observes("holderMarginChecked")

到目前为止我有这段代码,但是 item.methodToCall 函数没有被调用

methodsToDefine = [
    {checkerName: "standoutHolderChecked", methodToCall: "toggleParentStandout"},
    {checkerName: "holderPaddingChecked", methodToCall: "toggleParentPadding"},
    {checkerName: "holderMarginChecked", methodToCall: "toggleParentMargin"}
]

add_this = { }

for item in methodsToDefine
    add_this["#{item.checkerName}Changed"] = (->
        if @get("controller.parent.isLoaded")
            @get("controller")[item.methodToCall](@get(item.checkerName))
    ).observes(item.checkerName)

App.ColumnSetupView.reopen add_this

谁能告诉我我做错了什么?有一个更好的方法吗 ?我应该在混合中这样做吗?如果是这样,请

最佳答案

我不知道您的确切用例,但正如您所说,您描述的问题可以通过 Mixin 解决,请参阅 http://jsfiddle.net/pangratz666/a3Usx/

JavaScript:

App = Ember.Application.create();

var methodsToDefine = [
    {checkerName: "standoutHolderChecked", methodToCall: "toggleParentStandout"},
    {checkerName: "holderPaddingChecked", methodToCall: "toggleParentPadding"},
    {checkerName: "holderMarginChecked", methodToCall: "toggleParentMargin"}
];

App.Stalker = Ember.Mixin.create({
  init: function() {
    this._super();
    methodsToDefine.forEach(function(config) {
      // add an observer for checkerName - a change should call methodToCall
      Ember.addObserver(this, config.checkerName, this, config.methodToCall);
    }, this);
  },

  willDestroy: function() {
    this._super();

    // since we are good citizens, we remove the observers when the object is destroyed
    methodsToDefine.forEach(function(config) {
      Ember.removeObserver(this, config.checkerName, this, config.methodToCall);
    }, this);
  }
});

示例用例:

var myObj = Ember.Object.create(App.Stalker, {
  toggleParentStandout: function() {
    console.log("toggleParentStandout called");
  },
  toggleParentPadding: function() {
    console.log("toggleParentPadding called");
  },
  toggleParentMargin: function() {
    console.log("toggleParentMargin called");
  }
});

myObj.set('standoutHolderChecked', 42);
myObj.set('holderPaddingChecked', 'Buster');

另一种实现是使用数组 watchProperties 的混合,它是应观察的属性列表,参见 http://jsfiddle.net/pangratz666/bSF3Z/ :

JavaScript:

App = Em.Application.create();

App.Stalker = Ember.Mixin.create({
  init: function() {
    this._super();

    var props = this.get('watchProperties');
    Ember.assert("watchProperties should be an array", Ember.isArray(props));
    props.forEach(function(property) {
      // invoke <property>Changed when <property> changes ...
      Ember.addObserver(this, property, this, '%@Changed'.fmt(property));
    }, this);
  },

  willDestroy: function() {
    this._super();

    this.get('watchProperties').forEach(function(property) {
      Ember.removeObserver(this, property, this, '%@Changed'.fmt(property));
    }, this);
  }
});

var o = Ember.Object.create(App.Stalker, {
  // 'a b'.w() == ['a', 'b']
  watchProperties: 'a b'.w(),
  aChanged: function() {
    console.log("a changed");
  }
});

o.set('a', 123);

关于javascript - 如何动态地将观察者方法添加到 Ember.js 对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13186618/

相关文章:

javascript - 当我们想要选择具有动态ID的对象时,如何在coffescript jquery中使用ruby代码?

class - Coffeescript 类和变量

ember.js - 将 .findBy() 与 Ember 数据填充的数组 Controller 结合使用

javascript - 清除动态添加/删除输入的输入值

Javascript 在其他函数完成后执行函数

javascript - 引用错误: Can't find variable: $controller

jQuery .eq() 隐藏元素的问题?

javascript - 异步函数返回正确的值,但该值在链接时未定义

javascript - 在没有后端控制的情况下使 AJAX 应用程序可抓取

javascript - 将第 3 方模块导入 Ember