У меня есть таблица HTML, в которой каждая строка данных имеет уникальный атрибут id
.Я пишу скрипт, который опрашивает сервер на предмет данных и использует полученные результаты для повторной сортировки таблицы.С сервера я получаю массив, подобный следующему:
var order_arr = [6, 4, 2, 1, 5, 3]
, который я хочу использовать для визуальной повторной сортировки некоторых табличных данных, например:
<tr id="user-1">...</tr>
<tr id="user-2">...</tr>
<tr id="user-3">...</tr>
<tr id="user-4">...</tr>
<tr id="user-5">...</tr>
<tr id="user-6">...</tr>
, чтобы онпользователь так:
<tr id="user-6">...</tr>
<tr id="user-4">...</tr>
<tr id="user-2">...</tr>
<tr id="user-1">...</tr>
<tr id="user-5">...</tr>
<tr id="user-3">...</tr>
Я написал для этого код jQuery на jsFiddle , но я не знаю, является ли это лучшим методом.Он выбирает массив элементов <tr>
и сортирует их по соответствующему индексу идентификатора каждой строки.Он заканчивается вызовом .html()
, который просто заменяет все содержимое тела таблицы.
Итак .. tl; dr:
- Является ли этот код лучшимспособ визуально пересортировать таблицу HTML по массиву, содержащему желаемый порядок идентификаторов строк?
- Как я могу сделать это анимированным?Я думал, что вместо этого мог бы написать это как хак CSS, в котором каждая строка таблицы имеет абсолютную позицию, и я мог просто запустить
.animate()
после вычисления, какую позицию должна занимать каждая строка.Мысли против моего текущего кода?