Ember.js 余烬控制器:没有处理该操作

Ember.js 余烬控制器:没有处理该操作,ember.js,Ember.js,我花了几个小时浏览了相关的帖子,但是找不到正确的答案来解决我遇到的问题 我不断得到错误: 未捕获错误:未处理“编辑”操作。如果确实处理了该操作,则此错误可能是由于从控制器中的操作处理程序返回true而导致该操作冒泡 我认为控制器处理错误,或者它冒出了错误的路径 App.EventDetailsController = Ember.ObjectController.extend({ isEditing: false, actions: { edit: function() {

我花了几个小时浏览了相关的帖子,但是找不到正确的答案来解决我遇到的问题

我不断得到错误:

未捕获错误:未处理“编辑”操作。如果确实处理了该操作,则此错误可能是由于从控制器中的操作处理程序返回true而导致该操作冒泡

我认为控制器处理错误,或者它冒出了错误的路径

App.EventDetailsController = Ember.ObjectController.extend({
   isEditing: false,

actions: {
    edit: function() {
        this.set('isEditing', true);
    },

    doneEditing: function() {
        this.set('isEditing', false);
    }
    }
});


App = Ember.Application.create();

    App.Router.map(function() {
   // put your routes here
  this.route('events', {path: '/events'});
  this.route('createevent', {path: '/createevent'});
  this.route('eventdetails', {path: ':eventdetails_id'});
});

App.EventsRoute = Ember.Route.extend({
model: function() {
    return events;
}
});

App.EventDetailsRoute = Ember.Route.extend({
model: function(params) {
    return events.findBy('id', params.eventdetails_id);
}
});

有人知道为什么这样不行吗?

我怀疑这与没有使用正确的命名约定有关。如果您的路由名称为
EventDetailsRoute
,则该路由应在路由器中引用为
事件详细信息

您可能希望这样定义您的路由:

App.Router.map(function() {
    this.resource('events', function() {                            // /events         <-- your event listing
        this.resource('event', {path: ':event_id'}, function() {    // /events/1       <-- your event details
            this.route('edit');                                     // /events/1/edit  <-- edit an event
        }); 
        this.route('create');                                       // /events/create  <-- create your event
    });
});

此问题是由于模板和控制器名称不同而导致的。请检查您的模板和控制器名称

我也遇到过类似的问题。但在我的例子中,我从一个控制器动作调用了一个路由动作,在这个动作中,我使用了transitionToRoute

由于到另一个路由的转换甚至在路由操作完成之前就已完成,因此引发了错误“没有处理操作
actionName
。如果您确实处理了该操作,则该错误可能是由于控制器中的操作处理程序返回true导致该操作冒泡”


参考:

请显示模板。这解决了我的问题!非常感谢!
App.EventDetailsRoute = Ember.Route.extend({
    actions: {
        edit: function() {
            this.set('isEditing', true);
        },

        doneEditing: function() {
            this.set('isEditing', false);
        },

        //or maybe better:
        toggleEditing: function() {
            this.toggleProperty('isEditing');
        }
    },

    model: function(params) {
        return events.findBy('id', params.eventdetails_id);
    }
});