我查了几个小时的相关帖子,但找不到正确的答案来解决我遇到的问题。
我一直收到错误:
未捕获错误:没有处理动作'编辑'。如果您确实处理了该操作,则可以通过从控制器中的操作处理程序返回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);
}
});
有谁知道为什么这不起作用?
答案 0 :(得分:2)
您可能想要定义这样的路线:
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
});
});
除此之外,请注意动作在路径中冒泡,因此请尝试将动作处理程序移动到EventDetailsRoute。
阅读指南中有关它的部分:http://emberjs.com/guides/templates/actions/#toc_action-bubbling
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);
}
});
答案 1 :(得分:0)
我怀疑它与不使用正确的命名约定有关。如果您的路由名称为EventDetailsRoute
,则路由应在路由器中引用为event-details
。
答案 2 :(得分:0)
当我们的模板和控制器名称不同时,会导致此问题。请检查您的模板和控制器名称
答案 3 :(得分:0)
我也遇到过类似的问题。但在我的情况下,我从控制器动作调用了一个路由动作,其中我使用了 transitionToRoute 。
由于在完成路线行动之前已完成向另一条路线的过渡,因此错误被抛出&#34;什么都没有处理动作actionName
。如果您确实处理了该操作,则可以通过从控制器中的操作处理程序返回true来导致此错误,从而导致操作冒泡&#34;。
参考:https://discuss.emberjs.com/t/sending-action-from-current-controller-to-current-route/6018