KendoUI Grid对下拉选项选择应用过滤器

时间:2013-03-07 07:47:39

标签: jquery kendo-ui datasource kendo-grid

我有一个可过滤的列,它使用下拉列表作为模板,用户可以选择要过滤的选项。

如何在选择该选项时过滤它,而不是用户必须在选择后单击过滤按钮?

我的以下代码不起作用。选择完成后,网格将刷新而不应用过滤器,并重置下拉选项。

对于我的下拉菜单,我有:

function salesPersonFilter(element)
{
  element.kendoDropDownList({
    dataSource: [{Id: 0, Name: 'Jimbo Jones'}, {Id: 1, Name: 'Jimmy'}],
    dataTextField: 'Name',
    dataValueField: 'Name',
    optionLabel: 'Select salesperson',
    template: '#="<span class=\'filterTrigger\'>"+Name+"</span>" #'
  })
}

我已将click事件绑定到filterTrigger类:

$('.k-list .filterTrigger').click(function()
{
  applyFilters();
})

我包含applyFilters()函数作为参考:

function applyFilters() // Custom filters...
{
  var dupes = {};
  var finalFilters = [];

  $.each(filterBus, function(i, el) {
    if(!dupes[el.field])
    {
      dupes[el.field] = true;
      finalFilters.push(el);
    }
  });

  filterBus = finalFilters ;

  grid.dataSource.filter(finalFilters) ;
}

1 个答案:

答案 0 :(得分:0)

我设法这样做,但肯定有更好的方法吗?:

function salesPersonFilter(element)
  {
    element.kendoDropDownList({
      dataSource: [{Id: 60, Name: 'Sam'}, {Id: 5, Name: 'Jimmy'}],
      dataTextField: 'Name',
      dataValueField: 'Id',
      optionLabel: 'Select salesperson',
      template: '#="<span class=\'filterTrigger\' data-value=\'"+Id+"\'>"+Name+"</span>" #',
      select: function(e) 
      {// Dirty, is there a better way?
        html = e.item[0].outerHTML;
        html = html.substring(html.indexOf('data-value="')+12);
        traderId = html.substring(0, html.indexOf('"'));

        filterBus.push({
          field: 'traderId',
          operator: 'eq',
          value: traderId
        })
        $('.k-animation-container').hide();
        grid.dataSource.filter(filterBus);
      }
    })
  }