Class Ember.ControllerMixin
privateactions public
Inherited from Ember.ActionHandler packages/@ember/-internals/runtime/lib/mixins/action_handler.ts:27
The collection of functions, keyed by name, available on this
ActionHandler
as action targets.
These functions will be invoked when a matching {{action}}
is triggered
from within a template and the application's current route is this route.
Actions can also be invoked from other parts of your application
via ActionHandler#send
.
The actions
hash will inherit action handlers from
the actions
hash defined on extended parent classes
or mixins rather than just replace the entire hash, e.g.:
import Mixin from '@ember/object/mixin';
export default Mixin.create({
actions: {
displayBanner(msg) {
// ...
}
}
});
import Route from '@ember/routing/route';
import CanDisplayBanner from '../mixins/can-display-banner';
export default Route.extend(CanDisplayBanner, {
actions: {
playMusic() {
// ...
}
}
});
// `WelcomeRoute`, when active, will be able to respond
// to both actions, since the actions hash is merged rather
// then replaced when extending mixins / parent classes.
this.send('displayBanner');
this.send('playMusic');
Within a Controller, Route or Component's action handler,
the value of the this
context is the Controller, Route or
Component object:
import Route from '@ember/routing/route';
export default Route.extend({
actions: {
myAction() {
this.controllerFor("song");
this.transitionTo("other.route");
...
}
}
});
It is also possible to call this._super(...arguments)
from within an
action handler if it overrides a handler defined on a parent
class or mixin:
Take for example the following routes:
import Mixin from '@ember/object/mixin';
export default Mixin.create({
actions: {
debugRouteInformation() {
console.debug("It's a-me, console.debug!");
}
}
});
import Route from '@ember/routing/route';
import DebugRoute from '../mixins/debug-route';
export default Route.extend(DebugRoute, {
actions: {
debugRouteInformation() {
// also call the debugRouteInformation of mixed in DebugRoute
this._super(...arguments);
// show additional annoyance
window.alert(...);
}
}
});
Bubbling
By default, an action will stop bubbling once a handler defined
on the actions
hash handles it. To continue bubbling the action,
you must return true
from the handler:
Router.map(function() {
this.route("album", function() {
this.route("song");
});
});
import Route from '@ember/routing/route';
export default Route.extend({
actions: {
startPlaying: function() {
}
}
});
import Route from '@ember/routing/route';
export default Route.extend({
actions: {
startPlaying() {
// ...
if (actionShouldAlsoBeTriggeredOnParentRoute) {
return true;
}
}
}
});
model public
Defined in packages/@ember/controller/index.ts:54
The controller's current model. When retrieving or modifying a controller's
model, this property should be used instead of the content
property.
queryParams public
Defined in packages/@ember/controller/index.ts:63
Defines which query parameters the controller accepts.
If you give the names ['category','page']
it will bind
the values of these query parameters to the variables
this.category
and this.page
.
By default, query parameters are parsed as strings. This
may cause unexpected behavior if a query parameter is used with toggleProperty
,
because the initial value set for param=false
will be the string "false"
, which is truthy.
To avoid this, you may specify that the query parameter should be parsed as a boolean
by using the following verbose form with a type
property:
queryParams: [{
category: {
type: 'boolean'
}
}]
Available values for the type
parameter are 'boolean'
, 'number'
, 'array'
, and 'string'
.
If query param type is not specified, it will default to 'string'
.
target public
Defined in packages/@ember/controller/index.ts:36
The object to which actions from the view should be sent.
For example, when a Handlebars template uses the {{action}}
helper,
it will attempt to send the action to the view's controller's target
.
By default, the value of the target property is set to the router, and
is injected when a controller is instantiated. This injection is applied
as part of the application's initialization process. In most cases the
target
property will automatically be set to the logical consumer of
actions for the controller.