KendoUI ızgarası için bir arama kutusu oluşturmaya çalışıyorum. Bir alana dayalı bir arama yapmak için bir başlangıç yapabildim, ancak arama kutumdaki değerin, ızgaradaki tüm sütunları aramasını istiyorum. jsfiddle.net ancak işe almak gibi olamaz ....KendoUI Grid'deki Tüm Sütunları Ara
cevap
ben düşünüyorum (bkz veya mantık düğmesi):
function() {
grid.data("kendoGrid").dataSource.filter({
field: "ProductName",
operator: "contains",
value: $('#category').val()
});
}
Burada veya mantık operatörü kullanılarak çalıştı İki koşuldan biriyle eşleştirmek istiyorsanız
eq
-
fee
veya
eq
-
fi
diyelim.
Göstermek için fiddle numaranızı biraz değiştirdim. Arama kutusuna yazarsanız, ProductName
sütununa veya QuantityPerUnit
ile eşleşen kayıtları filtrelersiniz.
//change event
$("#category").keyup(function() {
var val = $('#category').val();
$("#grid").data("kendoGrid").dataSource.filter({
logic : "or",
filters: [
{
field : "ProductName",
operator: "contains",
value : val
},
{
field : "QuantityPerUnit",
operator: "contains",
value : val
}
]
});
});
ÖNEMLİ: Ben o iş yapmak için 1.8.2 jQuery sürümünü güncellemek zorunda ve her ihtimale karşı ben son sürümüne yanı, KendoUI ürünü güncelledik.
Sütun adları hakkında endişelenmek istemiyorsanız, bunun yerine bu kodu kullanabilirsiniz. Herhangi bir kılavuz üzerinde çalışacak ve kodlanmış sütun adlarını belirtmeden filtrelenebilir olarak işaretlenmiş tüm sütunları arayacaktır. Ayrıca, ek bir etkinlik ekledim, böylece birisi bir arama sorgusu kopyalayıp yapıştırırsa etkinlik çağrılırdı. (Bu ayrıca jQuery 1.83 veya üstü gerektirir). JQuery Datatables eklentisinden Kendo UI Grid'e geçtikten sonra bu kodu oluşturdum. Kendo'yu seviyorum ama DataTables tarafından sunulan global arama metin kutusunu gerçekten kaçırdım. Bu kodu tüm Kendo Izgaralarıma dahil ediyorum.
$("#category").on("keypress blur change", function() {
var filter = { logic: "or", filters: [] };
$searchValue = $(this).val();
if ($searchValue) {
$.each($("#grid").data("kendoGrid").columns, function(key, column) {
if(column.filterable) {
filter.filters.push({ field: column.field, operator:"contains", value:$searchValue});
}
});
}
$("#grid").data("kendoGrid").dataSource.query({ filter: filter });
});
Tam olarak ne yaptığımı, ancak şimdi sadece veri kaynağında bulunan gizli sütunları filtrelemeye çalışıyorum, şimdi muhtemelen başka bir yaklaşıma geçmek zorunda kalacağım –
Harika çalışma Mat .. Kendo UI kılavuzuna geçmek istiyorum Datatables grid'in yanı sıra, Bu yaygın arama özelliği, tüm bu günlerde bunu yapmamı engelliyordu. Şimdi bu tamamen Kendo UI ızgarasına geçmeme yardımcı oluyor. işin için teşekkürler –
OnaBai'nin yanıtı, veri tabloları gibi çalışmaz Veri tabloları, alanları alanlara ve alanlara göre işlemektedir. Eğer "chef 36" yazarsanız kemanda dataTables araması, bir sütunda şefi ve bir diğerinde 36 olduğu için 5'in bir productid'i olan satırı gösterecektir. doğru kod bu http://jsfiddle.net/Naka3/38/ gibi görünecekti.
$("#category").keyup(function() {
var selecteditem = $('#category').val();
var kgrid = $("#grid").data("kendoGrid");
selecteditem = selecteditem.toUpperCase();
var selectedArray = selecteditem.split(" ");
if (selecteditem) {
//kgrid.dataSource.filter({ field: "UserName", operator: "eq", value: selecteditem });
var orfilter = { logic: "or", filters: [] };
var andfilter = { logic: "and", filters: [] };
$.each(selectedArray, function (i, v) {
if (v.trim() == "") {
}
else {
$.each(selectedArray, function (i, v1) {
if (v1.trim() == "") {
}
else {
orfilter.filters.push({ field: "ProductName", operator: "contains", value:v1 },
{ field: "QuantityPerUnit", operator: "contains", value:v1});
andfilter.filters.push(orfilter);
orfilter = { logic: "or", filters: [] };
}
});
}
});
kgrid.dataSource.filter(andfilter);
}
else {
kgrid.dataSource.filter({});
}
});
- 1. iPhone, tüm albümleri/sanatçıları ara
- 2. ara
- 3. Tüm dosyaları tekrarlı olarak dizinlerde ara. NodejS
- 4. Tweepy (Twitter API) tüm ara dönersek Değil
- 5. Dize ara - Tüm oluşumları bul PHP
- 6. KendoUI Düzenleyicisi'ne yapıştırırken tüm html formatlarını metinden nasıl çıkarabilirim?
- 7. Oracle Tüm tabloları dize için tüm sütunlarda ara
- 8. KendoUI tablosu + AngularJS
- 9. ara
- 10. Raylar 3 Katılmadan Tüm Sütunları Geri Döndürme
- 11. Listedeki tüm veri çerçevelerinden NA'lı sütunları kaldırın
- 12. Ortak etiketle başlayan tüm sütunları nasıl seçeceksiniz
- 13. Tüm satırları ve sütunları tablodan yazdırılamıyor
- 14. R dplyr - tüm sütunları birbirinden bağımsız
- 15. R: Tüm sütunları bir ID sütunuyla daraltma
- 16. Tüm tabloları ve tüm sütunları odbc veritabanından alın
- 17. Sütunları
- 18. Ülke ara
- 19. KendoUi schedulardata zaman çizelgesinde görüntülenmiyor
- 20. TypeError: (ara değer) (ara değer) .success
- 21. Android Özel Arama Görünümü Ara Ara
- 22. Kişi ara
- 23. Bir zincirdeki tüm sertifikaların alınması; hem ara hem de kök
- 24. ElasticSearch NEST Çoklu Türleri ve Tüm Alanları Ara
- 25. Metne göre ara ve o satırdaki tüm değerleri bul
- 26. Eclipse'de Ekli Kaynaklarda Ara
- 27. Beyaz boşlukları kaldırarak bir tablodaki tüm sütunları yeniden adlandırma
- 28. 'pyspark.sql.types.Row' ifadesinin tüm sütunları/öznitelik adlarından nasıl alabilirim?
- 29. Bir linq sonucundan tüm sütunları nasıl birleştirme ile birleştirme
- 30. Data.frames'ın dizin listesi - tüm x-inci sütunları nasıl alınır?
Ben ancak çalışmıyor mantık operatörü kullanarak çalıştı ... $ ("# grid") verileri ("kendoGrid") dataSource.filter ({ mantık.:. "Veya" filtreler: [ {field: "ProductName", işleç: "ne", value: "fee"}, {field: "ProductName", işleç: "ne", value: "fi"} ] }); – BlueBird