博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
7.8 Models -- The Rest Adapter
阅读量:6153 次
发布时间:2019-06-21

本文共 4783 字,大约阅读时间需要 15 分钟。

一、概述

默认的,store将会使用 来加载和存储records。这个RESTAdapter假定URLS和JSON关联每一个model是约定好的;这意味着,如果你遵循这个规则,你将不需要配置这个adapter或者为了启动编写任何代码。

二、URL Conventions

1. 基于model的name,这个REST adapter足够的聪明来确定和它通信的URLS。例如,如果你通过一个ID请求一个Post

store.findRecord('post', 1).then(function(post) {});

2. 这个REST适配器将会自动发送一个Get请求到/posts/1

3. 对于多个word名字,这个REST适配器将会使用lower_snake_case

4. 你可以采取的action,在REST适配器中,映射到下面的URL:

Action HTTP Verb URL
Find Record GET /posts/123
Find All GET /posts
Update PUT /posts/123
Create POST /posts
Delete DELETE /posts/123

5. Pluralization customization(多元化定制)

可以通过Ember.Inflector.inflector指定不规则的或者不可数的多元化:

var inflector = Ember.Inflector.inflector;inflector.irregular('person', 'people');inflector.uncountable('advice');

这将告诉这个REST适配器,对于person的请求应该去请求/people/1而不是/persons/1

6. Endpoint path customization(终端的路径定制)

通过设定在适配器中的namespace属性,终端的路径可以被加上一个命名空间前缀:

app/adapters/application.js

export default DS.RESTAdapter.extend({  namespace: 'api/1'});

person的请求现在会导航到http://emberjs.com/api/1/people/1

7. Host customization(定制主机)

通过设定host属性,一个适配器可以导航到其他的hosts。

app/adapters/application.js

export default DS.RESTAdapter.extend({  host: 'https://api.example.com'});

请求person现在将会导航到https://api.example.com/people/1

三、JSON Conventions

1. 当请求一条record,这个REST适配器期望你的服务器返回一个JSON代表这条record,它符合下列惯例。

2. JSON ROOT

(1) 返回的主要record应该在一个命名的根中。例如,如果你从/people/123请求一条record,响应应该被嵌套进一个被称为person的属性中:

{  "person": {    "firstName": "Jeff",    "lastName": "Atwood"  }}

(2) 在destroyRecord之后或者在deleteRecord并且save之后,这个适配器期望服务器去返回一个空的对象({})。

(3) 如果你没有改变服务器返回的数据的选项,你可以重写这个,像这样:

extractDeleteRecord: function(store, type, payload) {  // If the payload is {delete: true}, Ember Data will try to set  // the new properties. Return null so it doesn't try to do that.  return null;}

3. Attribute Names

(1) 属性名字应该用驼峰命名法。例如,如果你有一个model,像这样:

app/models/person.js

export default DS.Model.extend({  firstName: DS.attr('string'),  lastName:  DS.attr('string'),  isPersonOfTheYear: DS.attr('boolean')});

从服务器返回的JSON应该像这样:

{  "person": {    "firstName": "Barack",    "lastName": "Obama",    "isPersonOfTheYear": true  }}

(2) 不规则的键可以被一个自定义的序列化器映射。如果person有一个名为lastNameOfPersonkey,并且期望的属性名字是简单的lastName,那么为这个model创建一个自定义的序列化器并且重写这个normalizeHash属性:

app/models/person.js

export default DS.Model.extend({  lastName: DS.attr('string')});

app/serializers/person.js

export default DS.RESTSerializer.extend({  normalizeHash: {    lastNameOfPerson: function(hash) {      hash.lastName = hash.lastNameOfPerson;      delete hash.lastNameOfPerson;      return hash;    }  }});

4. Relationships

(1) 引用其他的rcords应该通过ID。例如,如果你有一个model,它有一个hasMany关系:

app/models/post.js

export default DS.Model.extend({  comments: DS.hasMany('comment', { async: true })});

JSON应该编码这个关系为一个IDs数组:

{  "post": {    "comments": [1, 2, 3]  }}

postComments可以通过post.get('comments')被加载。对每一个相关的comment这个REST适配器将会发送一个Get请求。

post.get('comments');// GET /comments/1// GET /comments/2// GET /comments/3

(2) 你可以在你的适配器中通过设定 为true阻止发送多个请求:

app/adapters/application.js

export default DS.RESTAdapter.extend({  coalesceFindRequests: true});

这个REST适配器现在将会发送一个GET请求到/comments?ids[]=1&ids[]=2&ids[]=3

(3) 在JSON中任何belongsTo关系应该是Ember Data的模型名字的被驼峰化的版本。例如,如果你有一个model:

app/models/comment.js

export default DS.Model.extend({  post: DS.belongsTo('post')});

这个JSON应该编码这个关系为一个到另一个record的ID:

{  "comment": {    "post": 1  }}

(4) 如果需要这些命名约定可以被重写,通过实现keyForRelationship方法可以实现:

app/serializers/application.js

export default DS.RESTSerializer.extend({  keyForRelationship: function(key, relationship) {    return key + 'Ids';  }});

5. Sideloaded Relationships

为了减少必要HTTP请求的数量,你可以在你的JSON响应中sideload额外的records。Sideloaded records存在于JSON root之外,并且被代表一个hash数组:

{  "post": {    "id": 1,    "title": "Node is not omakase",    "comments": [1, 2, 3]  },  "comments": [{    "id": 1,    "body": "But is it _lightweight_ omakase?"  },  {    "id": 2,    "body": "I for one welcome our new omakase overlords"  },  {    "id": 3,    "body": "Put me on the fast track to a delicious dinner"  }]}

四、Creating custom transformations(创建自定义转化)

1. 在某些情况下,固有的属性类型string,number,booleandate可能会不够。例如,一个服务器可能返回一个不标准的日期格式。

2. Ember Data可以新注册一个JSON转换器作为属性:

app/transforms/coordinate-point.js

export default DS.Transform.extend({  serialize: function(value) {    return [value.get('x'), value.get('y')];  },  deserialize: function(value) {    return Ember.create({ x: value[0], y: value[1] });  }});

app/models/cursor.js 

export default DS.Model.extend({  position: DS.attr('coordinatePoint')});

coordinatePoint从API中被接收的时候,它被期望是一个数组:

{  cursor: {    position: [4,9]  }}

但是一旦加载到一个model实例,它将作为一个对象行为:

var cursor = this.store.findRecord('cursor', 1);cursor.get('position.x'); //=> 4cursor.get('position.y'); //=> 9

如果position被修改并且保存,在转换中它将通过serialize序列化函数并且在JSON中作为一个数组被再次发送。

转载于:https://www.cnblogs.com/sunshineground/p/5165975.html

你可能感兴趣的文章
eclipse decompiler
查看>>
记一个搜索网盘资源的网站
查看>>
jdk1.7和jdk1.8的String的getByte方法的差异
查看>>
java父子进程通信
查看>>
Android ADB server didn't ACK * failed to start daemon * 简单有效的解决方案
查看>>
Olap学习笔记
查看>>
Codeforces Round #431 (Div. 1)
查看>>
如何进行数组去重
查看>>
将标题空格替换为 '_' , 并自动复制到剪切板上
查看>>
List Collections sort
查看>>
Mysql -- You can't specify target table 'address' for update in FROM clause
查看>>
使用局部标准差实现图像的局部对比度增强算法。
查看>>
2017-2018-1 20165313 《信息安全系统设计基础》第八周学习总结
查看>>
《代码敲不队》第四次作业:项目需求调研与分析
查看>>
菜鸡互啄队—— 团队合作
查看>>
HttpWebRequest的GetResponse或GetRequestStream偶尔超时 + 总结各种超时死掉的可能和相应的解决办法...
查看>>
SparseArray
查看>>
第二章
查看>>
android背景选择器selector用法汇总
查看>>
[转]Paul Adams:为社交设计
查看>>