сейчас от большего к меньшему сортируется или наоборот?
вот код сортировки
table.prototype.getSortTable = function(){
let app = this
let tables = document.querySelector('.first-table');
let colIndex = -2;
let tableSort = function (index, type, isSorted) {
let tbody = tables.querySelector('tbody');
let compare = function(rowA, rowB) {
let rowDataA;
let rowDataB;
if (rowA.cells[index].hasAttribute('data-time') && rowB.cells[index].hasAttribute('data-time')){
rowDataA = rowA.cells[index].getAttribute('data-time');
rowDataB = rowB.cells[index].getAttribute('data-time');
}else{
rowDataA = rowA.cells[index].textContent;
rowDataB = rowB.cells[index].textContent;
}
switch (type) {
case 'integer':
case 'double':
return rowDataA - rowDataB;
break;
case 'date':
let dateA = rowDataA.split('.').reverse().join('-');
let dateB = rowDataB.split('.').reverse().join('-');
return new Date(dateA).getTime() - new Date(dateB).getTime();
break;
case 'text':
if (rowDataA < rowDataB) return -1;
if (rowDataA > rowDataB) return 1;
return 0;
break;
}
}
let rows = [].slice.call(tbody.rows);
rows.sort(compare);
if (isSorted) rows.reverse();
tables.removeChild(tbody);
for (let i = 0; i < rows.length; i++) {
tbody.appendChild(rows[i]);
}
tables.appendChild(tbody);
}
// Событие клика по шапке таблицы для сортировки данных
tables.addEventListener('click', function(event){
let target = event.target;
if(target.nodeName != 'TH') return false;
let index = target.cellIndex;
let type = target.getAttribute('data-type');
colIndex = (colIndex == index) ? -1 : index;
tableSort(index, type, colIndex == index);
console.log($(event.target))
if($(event.target).hasClass('up')){
$(event.target).removeClass('up')
$(event.target).addClass('down')
}else{
$(event.target).removeClass('down')
$(event.target).addClass('up')
}
});
}
https://pastebin.com/ уберите код сюда - невозможно читать нормально
https://pastebin.com/PVkvNaar
Решение "в лоб" - передавайте в функции compare флаг isDesc и в зависимости от него (истинный или ложный) меняйте местами: rowDataA - rowDataB на 24 строке; new Date(dateA).getTime() - new Date(dateB).getTime(); на 30 строке
Обсуждают сегодня