用法
包含 'datagrid-filter.js' 文件
启用过滤(Filter)
var dg = $('#dg');dg.datagrid(); // create datagriddg.datagrid('enableFilter'); // enable filter
属性
该属性扩展自数据网格(datagrid),下面是为数据网格(datagrid)添加的属性。
名称 | 类型 | 描述 | 默认值 |
---|---|---|---|
filterMenuIconCls | string | 过滤菜单项(指示要使用的项目)的图标 class。 | icon-ok |
filterBtnIconCls | string | 过滤按钮的图标 class。 | icon-filter |
filterBtnPosition | string | 过滤按钮的位置。可能的值是 'left' 和 'right'。 | right |
filterPosition | string | 过滤栏相对于列的位置。可能的值是 'top' 和 'bottom'。 | bottom |
remoteFilter | boolean | 设置为 true 则执行远程过滤。 当启用时,'filterRules' 参数将发送到远程服务器。 'filterRules' 参数的值由 'filterStringify' 函数获得。 | false |
filterDelay | number | 从 'text' 过滤组件中最后一个键输入事件起,延迟执行过滤的时间。 | 400 |
filterRules | array | 过滤规则的定义。每个规则包含 'field'、'op' 和 'value' 属性。 | [] |
filterStringify | function | 把过滤规则字符串化的函数。 | function(data){ return JSON.stringify(data);} |
方法
下面的方法扩展自数据网格(datagrid)。
名称 | 参数 | 描述 |
---|---|---|
enableFilter | filters | 创建并启用过滤功能。 'filters' 参数是一个过滤配置的数组。 每一项包含下列属性: 1) field:需要定义规则的域。 2) type:过滤类型,可能的值:label、text、textarea、checkbox、numberbox、validatebox、datebox、combobox、combotree。 3) options:过滤类型的选项。 4) op:过滤操作,可能的值:contains、equal、notequal、beginwith、endwith、less、lessorequal、greater、greaterorequal。 代码实例: $('#dg').datagrid('enableFilter');$('#dg').datagrid('enableFilter', [{ field:'listprice', type:'numberbox', options:{precision:1}, op:['equal','notequal','less','greater']}]); |
addFilterRule | param | 添加一个过滤规则。$('#dg').datagrid('addFilterRule', { field: 'desp', op: 'contains', value: 'easyui'}); |
removeFilterRule | field | 移除过滤规则。 如果 'field' 参数未指定,移除所有的过滤规则。 |
doFilter | none | 基于过滤规则执行过滤。 |
getFilterComponent | field | 在指定的域上获取过滤组件。 |
示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 | $( '#calllist' ).datagrid({ filterBtnIconCls: 'icon-filter' , iconCls: 'icon-files' , url: 'getMyCallList.asp' , //width: ($(window).width() * 0.9), height: ($(window).height() * 0.8), fitColumns: true , //列自适应 nowrap: false , rownumbers: true , loadMsg: '正在加载信息...' , pagination: true , //是否有分页 loadFilter:pagerFilter, //singleSelect: false,//是否单行选择 pageSize: 10, //每页多少条数据 pageNumber: 1, //默认的页 pageList: [10, 20, 30], queryParams: pars, //往后台传递参数 //onLoadSuccess: onLoadSuccess,//加载完毕后执行计算 columns: [[ { field: 'phone' , title: '电话号码' , align: 'center' , width: 100 }, { field: 'names' , title: '姓名' , align: 'center' , width: 100 }, { field: 'sex' , title: '性别' , align: 'center' , width: 100 }, { field: 'age' , title: '年龄' , align: 'center' , width: 100 }, { field: 'Education' , title: '教育程度' , align: 'center' , width: 100 }, { field: 'applyposition' , title: '应聘职位' , align: 'center' , width: 100 }, { field: 'source' , title: '来源' , align: 'center' , width: 100 }, { field: 'connectType' , title: '接通类型' , align: 'center' , width: 100 }, { field: 'connectedStatus' , title: '接通状态' , align: 'center' , width: 100 }, { field: 'NotConnectedStatus' , title: '未接通状态' , align: 'center' , width: 100 }, { field: 'calldate' , title: '联系时间' , align: 'center' , width: 100 }, { field: 'operation' , title: '操作' , align: 'center' , width: 100, formatter: function (rowIndex,row) { var str = "" ; str += '<a href="javascript:OpenInfo(\'' + row.id + '\');" class="easyui-linkbutton c4" tyle="width:50px" >面试</a>' ; str += '<a href="deleteInfo.asp?id=' +row.id+ '" class="easyui-linkbutton c5" tyle="width:50px">删除</a>' ; return str; } } ]], toolbar: '#sec' , }); $( '#calllist' ).datagrid( 'enableFilter' ); |
需要注意的是, $('#calllist').datagrid('enableFilter');激活过滤功能需要在数据加载完成之后同步执行,不能单独放到$(function(){......})