init
The constructor of the filter.
Parameters
options Object
An object which may contain the following keys:
-
values
- an array of the matching values that should be preserved. -
blanks
- if set as true, empty cells will be shown, too. -
dates
- an array which works like thevalues
option, but performs partial matching for date values. It should contain objects withyear
,month
,day
,hours
,minutes
, andseconds
. Each field is optional.
Example - filter a range by values
<div id="spreadsheet"></div>
<script type="text/javascript" charset="utf-8">
$("#spreadsheet").kendoSpreadsheet();
var spreadsheet = $("#spreadsheet").data("kendoSpreadsheet");
var sheet = spreadsheet.activeSheet();
var values = [
[ "C 1", "C 2", "C 3" ],
[ 7, 5, 6 ],
[ 7, 8, 9 ],
[ 6, 3, 9 ]
];
sheet.range("A1:C4").values(values);
var filter = new kendo.spreadsheet.ValueFilter({ values: [ 7 ] });
sheet.range("A1:C4").filter([ { column: 0, filter: filter } ]);
</script>
Example - filter a range by values with blanks
<div id="spreadsheet"></div>
<script type="text/javascript" charset="utf-8">
$("#spreadsheet").kendoSpreadsheet();
var spreadsheet = $("#spreadsheet").data("kendoSpreadsheet");
var sheet = spreadsheet.activeSheet();
var values = [
[ "C 1", "C 2", "C 3" ],
[ 7, 5, 6 ],
[ 7, 8, 9 ],
[ null, 8, 9 ],
[ 6, 3, 9 ]
];
var range = sheet.range("A1:C5");
range.values(values);
var filter = new kendo.spreadsheet.ValueFilter({ values: [ 7 ], blanks: true });
range.filter([ { column: 0, filter: filter } ]);
</script>
Example - filter a range with dates
<div id="spreadsheet"></div>
<script type="text/javascript" charset="utf-8">
$("#spreadsheet").kendoSpreadsheet();
var spreadsheet = $("#spreadsheet").data("kendoSpreadsheet");
var sheet = spreadsheet.activeSheet();
var values = [
[ "C 1", "C 2", "C 3" ],
[ new Date(2000, 10, 10), 5, 6 ],
[ new Date(2010, 10, 10), 8, 9 ],
[ null, 8, 9 ],
[ new Date(2000, 1, 1), 3, 9 ]
];
var range = sheet.range("A1:C5");
range.values(values);
var filter = new kendo.spreadsheet.ValueFilter({ dates: [ { year: 2000 } ], blanks: true });
range.filter([ { column: 0, filter: filter } ]);
</script>