モデルにオブジェクトのリストがあることを剣道グリッドでフィルタリングしたい。
連絡先のリストでフィルタが機能しない:
ここに私のJavaScriptコードがあります:
var typeFilter;
var contactsFilter;
var datesFilter;
var ByFiler;
var zeroFilter = {
field: "ID",
operator: "eq",
value: 0
};
function filterOnMultiSelectContacts(e) {
var filters;
for (var i = 0; i < $('#ContactsDropDownFilter').data("kendoMultiSelect").dataItems().length; i++)
{
filters =[
{
field: "Contacts.ContactID",
operator: "eq",
value: Number($('#ContactsDropDownFilter').data("kendoMultiSelect").dataItems()[i].ContactID)
},
zeroFilter
]
}
contactsFilter = {
logic: "or",
filters: filters
};
applyFilters();
}
function TypeChanged(e) {
var type = $("#SelectedType").val();
var value = Number(type);
if (value === -1) {
typeFilter = null;
}
else {
typeFilter = {
logic: "or",
filters: [
{
field: "Type",
operator: "eq",
value: value
},
zeroFilter
]
};
}
applyFilters();
}
function applyFilters() {
var ds = $("#Grid").data("kendoGrid").dataSource;
var filters = [];
if (typeFilter) filters.push(typeFilter);
if (contactsFilter) filters.push(contactsFilter);
if (datesFilter) filters.push(datesFilter);
ds.filter(filters);
}
フィールド(モデル)が配列ではないため、日付とタイプのフィルターは正常に機能しています。一方、私のfilterOnMultiSelectContacts()
機能は正しく機能していません。私の間違いはこの行だと思いfield: "Contacts.ContactID"
ます。この行は、正しい ContactID を取得することで正常に機能しています。
Number($('#ContactsDropDownFilter').data("kendoMultiSelect").dataItems()[i].ContactID)
ちなみに、グリッド用のカミソリ データソースは次のとおりです。
.DataSource(dataSource => dataSource
.Ajax()
.ServerOperation(false)
.Events(e => e.Sync("SyncLogEventGrid"))
.Model(m =>
{
m.Id(t => t.LogEventID);
m.Field(u => u.CreatedByContact).DefaultValue(UserHelper.GetCurrentUserContact(Request.RequestContext));
m.Field(u => u.CreatedBy).DefaultValue(UserHelper.GetCurrentUserContact(Request.RequestContext).ContactID);
m.Field(u => u.Contacts).DefaultValue(new List<ContactModel>());
m.Field(u => u.LogEventAttachments).DefaultValue(new List<LogEventAttachmentModel>());
})
)
編集
(オブジェクト全体ではなく) 連絡先の ID を含む ContactIds をモデルに追加しました。私はこれを思いつきましたが、まだ機能していません...
function filterOnMultiSelectContacts(e) {
contactsFilter = null;
var ContactIdsList = new Array();
for (var i = 0; i < $('#LogEventContactsDropDownFilter').val().length; i++)
{
ContactIdsList.push(Number($('#LogEventContactsDropDownFilter').val()[i]));
}
var filters;
if ($('#LogEventContactsDropDownFilter').data("kendoMultiSelect").dataItems().length > 0) {
filters = [
{
field: "ContactIDs",
operator: "eq",
value: ContactIdsList
}
,
zeroFilter
];
contactsFilter = {
logic: "or",
filters: filters
};
}
else
{
contactsFilter = null;
}
applyFilters();
}