Задать вопрос
@Jazz75RUS

Как сделать формирование списка в зависимости от класса или значения?

Добрый день, есть три полосы списка, сверху вниз:
<li class="1">31</li>
<li class="2">11</li>
<li class="3">16</li>

Каким способом можно реализовать изменение положения полос в зависимости от их значения (или класса), например если в полосе class=3 значение становится 36 то она перемещается (можно при перезагрузке, без аякса) в самый верх, а если в class=1 будет 12 то она становится 2й по счету? Пример готовой реализации очень приветствуется но не обязателен)) Спасибо.
Даже совсем обнаглею...мож кто за пивас сделает?))
  • Вопрос задан
  • 257 просмотров
Подписаться 1 Оценить Комментировать
Решения вопроса 1
@mrtoxa
var list = document.querySelector('.sort-list');
var sortElem = list.getElementsByTagName('li');
var nEntryArray = Array.prototype.slice.call(sortElem, 0);

nEntryArray.sort(function(a, b) {
  return a.firstChild.nodeValue - b.firstChild.nodeValue
})

while (list.lastChild) {
  list.removeChild(list.lastChild);
}

var sortList = document.createDocumentFragment();
for (i = 0, l = nEntryArray.length; i < l; i++) {
  sortList.appendChild(nEntryArray[i]);
}
list.appendChild(sortList);

<ul class="sort-list">
<li class="l1">31</li>
<li class="l2">11</li>
<li class="l3">16</li>
</ul>

И даже ради примера не называйте классы с цифры. Вообще ничего и никогда не называйте с цифры.
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
@vashaaa
Юх с горы
В чем трудности то. Jquery в помощь. Парсите ваш список (вряд-ли там будет только 3 елемента, тогда можно было обойтись одной перестановкой), считываете в массив, сортируете как надо и с этого вот клепатете себе новый список(на месте старого конечно же). С классами так же.
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 дек. 2024, в 14:07
15000 руб./за проект
22 дек. 2024, в 13:01
50000 руб./за проект
22 дек. 2024, в 10:44
15000 руб./за проект