Adapter、Fixture Adapter和REST Adapter之间的区别是什么,以及何时使用它们?
发布于 2012-08-11 12:41:05
使用DS.FixtureAdapter (或DS.FixtureAdapter.create()),而不是(还没有?)注意与后端通信,但会将数据存储为客户端中的“fixture”。一旦声明了一个模型:
App.Thing = DS.Model.extend({
name: DS.attr('string'),
// ...
});您可以定义您的装置:
App.Thing.FIXTURES = [
{
id: 1,
name: '...',
// ...
},
{
id: 2,
name: '...',
// ...
},
];然后你可以对它们使用ember data方法(例如App.Thing.findAll()等)。并对它们进行操作,但当然它只会在页面(即javascript环境)存在的时间内持续存在。
DS.RestAdapter虽然显然仍在开发中,但仍然可以使用,其设计目的是很好地适应Rails API,但可能会被修改/扩展以与您正在使用的任何RESTful API一起工作。它知道通过调用/things来处理App.Thing.findAll(),并通过调用/things/12来处理App.Thing.find(12)。这是一个相对路径,附加在传入的名称空间参数后面:
App.store = DS.Store.create({
revision: 4,
adapter: DS.RestAdapter.create({
namespace: 'http://what.ever/api/v1'
})
});DS.Adapter相当抽象:前面提到的内置适配器的超类。如果这两个都不适合您的需求,那么您很可能希望实现您自己的:
App.adapter = DS.Adapter.create({
find: function(store, type, id) {
// ...
jQuery.get( ... , function(data) {
store.load(type, id, data);
});
},
createRecord: function(store, type, model) {
// ...
jQuery.post( ... , function(data) {
store.didCreateRecord(model, data);
});
},
// ...
});
App.store = DS.Store.create({
revision: 4,
adapter: App.adapter
});希望这能有所帮助。有关更多信息,请参阅https://github.com/emberjs/data上的自述文档。
https://stackoverflow.com/questions/11910496
复制相似问题