Ember 数据只是不会将参数附加到查询中。我有这样的标签路线
例子
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"}
(host url) + api/v1/entries.json
GET
Object {data: Object}
(host url) + api/v1/entries.json?tags=tag
Class {type: function, query : Object, store: Class, isLoaded: true, meta: Object...}
Ember 数据附加 GET 参数。我认为我的错误可能是请求的 url,它应该是这样的
(host url) + api/v1/tags/:tag_name.json
而不是
(host url) + 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);
感谢您的帮助