169 похожих чатов

Всем привет! подскажите, как при сортировке строк в таблице, узнать,

сейчас от большего к меньшему сортируется или наоборот?
вот код сортировки

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')
}
});
}

3 ответов

6 просмотров

https://pastebin.com/ уберите код сюда - невозможно читать нормально

Юрий Kolomenkov
https://pastebin.com/PVkvNaar

Решение "в лоб" - передавайте в функции compare флаг isDesc и в зависимости от него (истинный или ложный) меняйте местами: rowDataA - rowDataB на 24 строке; new Date(dateA).getTime() - new Date(dateB).getTime(); на 30 строке

Похожие вопросы

Обсуждают сегодня

коллеги, добрый вечер! А никто не знает как модальная форма может себя закрыть? Ну допустим модальная форма определила, что смысла ей работать нет и хочет вернуть modalResult...
Михаил
83
А если изначально бот работал так : есть сайт онлайн школы. У каждого ученика свой кабинет. Где он авторизуется по своим данным. И уже в кабинете, на самом сайте делает оплату...
Денис 💡 Фрилансер
13
Добрый день Хочу начать обучение языку, не являюсь представителем it, буду благодарна за помощь, совсем пока не понимаю ничего) Подскажите, пожалуйста, где можно начать первы...
Sara Lala
19
А что ты вообще делаешь ?
Yesgoter
13
средствами IBX как-то можно выполнить запрос insert ... returning?
Igor
31
На работе пишем распределенное приложение, у которого сотни, если не тысячи настроек. Конфиги написаны на xml, расположены на разных хостах и должны быть согласованы друг с др...
Aleksandr Druzhinin
5
Всем привет 🙂 Какая-то непонятная проблема у меня с видео, раньше такого не было. Загружаю видео с гугл диска именно в видео mp4 и меняю ссылку как положено вот она: https://d...
Ксюша|Верстка на Тильде|Дизайн 🦥
6
Hi there everyone Is there anyone who have not started hamster bot yet? I need only one, I'll be glad if you do this for me DM if you haven't yet
Mehrshad
53
А как старый хаскел с новым стыковать ? потому как тут работает https://play.haskell.org/saved/C3xpMzcd, а вот тут https://stepik.org/lesson/7602/step/9?unit=1473 нет ошибка C...
Fedor
131
А какие у этого try практические плюсы перед eval?
Oleg Volkov
41
Карта сайта