example
App.TagsRoute = Ember.Route.extend({
model: function(params) {
var tag = params.tag_name;
var entries = this.store.find('entry', {tags: tag});
return entries;
}
});
但是这会使得相同的请求不断发出,就像这个代码:this.store.find('entry')。
编辑:
我的路由器看起来像这样:
App.Router.map(function(){
this.resource('entries', function(){
this.resource('entry', { path: '/entry/:entry_id/:entry_title' });
});
this.route('tags', { path: '/t/:tag_name' });
});
当我请求(例如)localhost:8888/#/t/tag时,params.tag_name的值为“tag”。
编辑2:
我的REST适配器
App.ApplicationAdapter = DS.RESTAdapter.extend({
bulkCommit: false,
buildURL: function(record, suffix) {
var s = this._super(record, suffix);
return s + ".json";
},
findQuery: function(store, type, query) {
var url = this.buildURL(type.typeKey),
proc = 'GET',
obj = { data: query },
theFinalQuery = url + "?" + $.param(query);
console.log(url); // this is the base url
console.log(proc); // this is the procedure
console.log(obj); // an object sent down to attach to the ajax request
console.log(theFinalQuery); // what the query looks like
// use the default rest adapter implementation
return this._super(store, type, query);
}
});
编辑3:
对我的TagsRoute对象进行一些更改后,我得到了以下输出:
App.TagsRoute = Ember.Route.extend({
model: function(params) {
var tag = params.tag_name;
var query = {tags: tag};
console.log(query);
var entries = this.store.find('entry', query);
return entries;
}
});
当我请求localhost:8888/#/t/tag时,控制台输出如下:
Object {tags: "tag"}
(主机网址)+ api/v1/entries.json
GET
Object {data: Object}
(主机网址)+ api/v1/entries.json?tags=tag
Class {type: function, query: Object, store: Class, isLoaded: true, meta: Object…}
Ember数据正在附加GET参数。我认为我的错误可能是所请求的网址,应该像这样:
(主机网址) + api/v1/tags/:tag_name.json
而不是
(主机网址) + api/v1/entries.json?tags=:tag_name
解决方法:
Ember Data的版本有问题(ember-data 1.0.0-beta.3-16-g2205566)。当我将脚本src更改为builds.emberjs.com.s3.amazonaws.com/canary/daily/20131018/ember-data.js时,一切正常工作。
添加GET参数的正确方式是:
var query = {param: value};
var array = this.store.find('model', query);
感谢您的帮助。