DS.RESTSerializer Class
Extends: DS.JSONSerializer
Defined in: addon/serializers/rest.js:16
Module: ember-data
Normally, applications will use the RESTSerializer
by implementing the normalize
method.
This allows you to do whatever kind of munging you need, and is especially useful if your server is inconsistent and you need to do munging differently for many different kinds of responses.
See the normalize
documentation for more information.
Across the Board Normalization
There are also a number of hooks that you might find useful to define across-the-board rules for your payload. These rules will be useful if your server is consistent, or if you're building an adapter for an infrastructure service, like Firebase, and want to encode service conventions.
For example, if all of your keys are underscored and all-caps, but otherwise consistent with the names you use in your models, you can implement across-the-board rules for how to convert an attribute name in your model to a key in your JSON.
app/serializers/application.js
import DS from 'ember-data'; export default DS.RESTSerializer.extend({ keyForAttribute: function(attr, method) { return Ember.String.underscore(attr).toUpperCase(); } });
You can also implement keyForRelationship
, which takes the name of the relationship as the first parameter, the kind of relationship (hasMany
or belongsTo
) as the second parameter, and the method (serialize
or deserialize
) as the third parameter.
Please login to continue.