Я использую этот very handy plugin для сортировки элементов. Но сравнение элементов по числовому значению приводит к некорректному результату: 99, 98, 9, 83, 8, 78 и т. Д.Сортировка элементов с использованием jquery (проблема с численными сопоставимыми данными)
Будет ли это проблемой для плагина или того, как я его реализовал?
Код:
<html>
<head>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
<script language="javascript">
jQuery.fn.sortElements = (function(){
var sort = [].sort;
return function(comparator, getSortable) {
getSortable = getSortable || function(){return this;};
var placements = this.map(function(){
var sortElement = getSortable.call(this),
parentNode = sortElement.parentNode,
nextSibling = parentNode.insertBefore(
document.createTextNode(''),
sortElement.nextSibling
);
return function() {
if (parentNode === this) {
throw new Error(
"You can't sort elements if any one is a descendant of another."
);
}
parentNode.insertBefore(this, nextSibling);
parentNode.removeChild(nextSibling);
};
});
return sort.call(this, comparator).each(function(i){
placements[i].call(getSortable.call(this));
});
};
})();
$(document).ready(function(){
$('.item').sortElements(function(a,b){
return $(a).html() < $(b).html() ? 1 : -1;
});
});
</script>
</head>
<body>
<% for i = 0 to 100 %>
<div class="item"><%=i*Rnd%></div>
<% next %>
</body>
</html>
parseFloat (строка) –
@GauravShah, да поддержать десятичного 'parseFl oat' следует использовать .. Я пошел с примерными значениями, которые являются целыми .. –
Это было всего лишь предложение опроснику :) –