Сортировка в сетке кендо с использованием пользовательских значений
Нужна помощь в сортировке этих результатов JSON по дням внутри kendoGrid. Мне нужен способ превратить знак плюс в.5 или что-то в этом роде. Я полагаю, что мне нужно пройтись по каждой из них, если я найду знак плюс, затем измените значение на число 5, а затем верну новое значение перед отображением?
{ name: Alex, days: "2" },
{ name: Jason, days: "1" },
{ name: Fred, days: "2+" },
{ name: Jane, days: "3" },
{ name: John, days: "3+" }
1 ответ
Вот код, который я получил работать
<body>
<div id="grid">
</div>
<div>
<script>
$(document).ready(function () {
//JSON data
var people = [
{ firstName: "Hasibul", lastName: "Haque", email: "hasibul2363@gmail.com", rank:"2" }
, { firstName: "Jane", lastName: "Smith", email: "jane.smith@kendoui.com", rank: "3+" }
, { firstName: "Jason", lastName: "Doe", email: "hasibul2363@gmail.com", rank: "1" }
, { firstName: "John", lastName: "doe", email: "hasibul2363@gmail.com", rank: "3+" }
, { firstName: "Joan", lastName: "doe", email: "hasibul2363@gmail.com", rank: "5" }
, { firstName: "Jack", lastName: "doe", email: "hasibul2363@gmail.com", rank: "3" }
, { firstName: "Jacob", lastName: "doe", email: "hasibul2363@gmail.com", rank: "3-" }
, { firstName: "Joe", lastName: "doe", email: "hasibul2363@gmail.com", rank: "3-" }
];
$('#grid').kendoGrid({
dataSource: {
type: "json",
data: people,
pageSize: 15,
sort: ({ field: "rank" })
},
sortable: true,
columns:[{
field: "rank",
sortable: {
compare: function (a, b, asc) {
var s1 = a.rank;
var s2 = b.rank;
var n1, n2;
var sg1, sg2;
var plus = s1.indexOf('+');
var minus = s1.indexOf('-');
if(plus >= 0){
n1 = parseInt(s1.substr(0, plus));
sg1 = 1;
}
else if(minus >= 0){
n1 = parseInt(s1.substr(0, minus));
sg1 = -1;
}
else{
n1 = parseInt(s1);
sg1 = 0;
}
plus = s2.indexOf('+');
minus = s2.indexOf('-');
if (plus >= 0) {
n2 = parseInt(s2.substr(0, plus));
sg2 = 1;
}
else if (minus >= 0) {
n2 = parseInt(s2.substr(0, minus));
sg2 = -1;
}
else {
n2 = parseInt(s2);
sg2 = 0;
}
if (n1 == n2) {
return sg2 - sg1;
} else {
return n2 - n1;
}
}
}
}]
,
pageable: {
buttonCount: 1
},
schema: {
data: "people"
}
//binding JSON data with grid
});
});
</script>