在Ember中从观察者调用控制器内部的函数



我有一个这样的控制器

App.TestController = Ember.ArrayController.extend({
    navigation:[],
    somefunc:function(){
      //do something
    }
});

的观察者
globalvars = Ember.Object.create({
    page : 1,
});
globalvars.addObserver('page', function() {
    this.get('controller.controllers.Test').somefunc();
});

问题是我不能在控制器内部调用函数

正如我在评论中已经提到的,这里有一个免责声明:

你应该更详细地解释你想要完成的任务。您试图以一种奇怪的方式访问控制器。

但是如果你必须这样做,这里有一个方法:

var App = Ember.Application.create({});
// put the global vars into the App object instead of polluting the global namespace
App.globalvars = Ember.Object.create({
    page : 1,
});

不是将观察者放在globalVars对象中,而是在控制器中声明观察者:

App.TestController = Ember.ArrayController.extend({
    navigation:[],
    somefunc:function(){
      //do something
    },
    globalVarsPageObserver : function(){
        this.somefunc();
    }.observes("App.globalvars.page")
});

最新更新