我试图按价格和评分对结果列表进行排序。为了简单起见,我刚刚收录了2个结果:Rider's Lodge和Olina Lodge。我写了一个可以单向排序的函数。jQuery按升序和降序排序(不是表格)
如何重新使用相同的函数对我的结果进行排序,以便点击'按价格排序'按升序排序,再次点击它按降序排序并在两者之间切换?
<div class="tab-content">
<div id="filters">
<p>
<a href="javascript:sort_by_rating();">Sort by Rating</a>
<br>
<a href="javascript:sort_by_price();">Sort by Price</a>
</p>
</div>
<div id="div_hotel_results" class="tab-pane active">
<form id="hotel-form">
...
</form>
<div class="results-row">
<h5>Riders Lodge</h5>
<span class="label label-info price">$103.64</span>
<span class="rating" data-rating="3.0">3.0</span>
</div>
<div class="results-row">
<h5>Olina Lodge</h5>
<span class="label label-info price">$99.64</span>
<span class="rating" data-rating="2.5">2.5</span>
</div>
</div>
</div>
<script type="text/javascript">
function sort_by_price() {
var sorted_list = [];
$('.price').each(function (index) {
sorted_list[index] = $(this).parent().parent().remove();
sorted_list[index]['cleaned_price'] = parseFloat($(this).text().replace(/[^0-9\.]+/g,""));
});
sorted_list.sort(function (a, b) {
if (a['cleaned_price'] == b['cleaned_price']) {
return 0;
} else if (a['cleaned_price'] > b['cleaned_price']) {
return 1;
} else {
return -1;
}
});
$('#hotel-form').after(sorted_list);
}
</script>
你想要的功能评价/价格之间既升序排序,desceding和开关? – 2013-03-24 15:34:51