Fixture包含联系人列表,每个联系人都有联系人类型。 我试图使用.findQuery()来过滤联系人记录,但它引发了以下错误:
Uncaught TypeError: Object function () {.....} has no method 'findQuery'
我在这里列出了我的代码:
Grid.Store = DS.Store.extend({
revision: 12,
adapter: 'DS.FixtureAdapter'
});
Grid.ModalModel = DS.Model.extend({
fname: DS.attr('string'),
lname: DS.attr('string'),
email: DS.attr('string'),
contactno: DS.attr('string'),
gendertype: DS.attr('boolean'),
contactype: DS.attr('number')
});
Grid.ModalModel.FIXTURES = [
{
id: 1,
fname: "sachin",
lname: "gh",
email: "gh",
contactno: "4542154",
gendertype: true,
contactype: 1
},
{
id: 2,
fname: "amit",
lname: "gh",
email: "gh",
contactno: "4542154",
gendertype: true,
contactype: 2
},
{
id: 3,
fname: "namit",
lname: "gh",
email: "gh",
contactno: "4542154",
gendertype: true,
contactype: 1
}
];
控制器代码:
totpersonalcontact:function(){
return Grid.ModalModel.findQuery({ contactype: 2 }).get('length');
}.property('@each.isLoaded'),
totfriendcontact:function(){
return Grid.ModalModel.findQuery({ contactype: 3 }).get('length');
}.property('@each.isLoaded')
我已将.findQuery更改为.query,但每次将长度显示为0时。
答案 0 :(得分:17)
只需将findQuery
更改为query
。
此后,控制台中将显示错误消息:
Assertion failed: Not implemented: You must override the DS.FixtureAdapter::queryFixtures method to support querying the fixture store.
与消息说明一样,只需实现DS.FixtureAdapter#queryFixtures
即可。
传递给queryFixtures
的参数是:记录,查询,类型。其中:
Records
是一组普通的javascript对象,您将对其进行过滤。 Query
是传递给您的余烬数据类的query
方法的对象。Type
是ember数据类,调用查询。返回的是过滤后的数据。
例如,执行一个简单的地方:
App.Person.query({ firstName: 'Tom' })
只需重新打开DS.FixtureAdapter
:
DS.FixtureAdapter.reopen({
queryFixtures: function(records, query, type) {
return records.filter(function(record) {
for(var key in query) {
if (!query.hasOwnProperty(key)) { continue; }
var value = query[key];
if (record[key] !== value) { return false; }
}
return true;
});
}
});
Here是一个现场演示。