我正在尝试按内容日期对div进行排序... 我得到的是排序。但不是按日期......
HTML
<div id="all_elements">
<!-- one element -->
<div class="element">
<div class="display-number">02</div>
<div class="year">20-10-2011</div>
</div><!-- element -->
<!-- one element -->
<div class="element">
<div class="display-number">03</div>
<div class="year">22-09-2011</div>
</div><!-- element -->
<!-- one element -->
<div class="element">
<div class="display-number">01</div>
<div class="year">01-12-2011</div>
</div><!-- element -->
<!-- one element -->
<div class="element">
<div class="display-number">04</div>
<div class="year">01-06-2011</div>
</div><!-- element -->
<!-- one element -->
<div class="element">
<div class="display-number">05</div>
<div class="year">01-06-2010</div>
</div><!-- element -->
</div> <!--all_elements-->
JQUERY
<script>
function sortDescending(a, b) {
return $(a).find(".year").text() < $(b).find(".year").text() ? 1 : -1;
};
$(document).ready(function() {
$('#all_elements .element').sort(sortDescending).appendTo('#all_elements');
});
</script>
我知道我需要一个函数来弄清楚内容是一个日期.. 只是不知道怎么......
谁能帮助我?
答案 0 :(得分:18)
你可以这样做:
function sortDescending(a, b) {
var date1 = $(a).find(".year").text();
date1 = date1.split('-');
date1 = new Date(date1[2], date1[1] -1, date1[0]);
var date2 = $(b).find(".year").text();
date2= date2.split('-');
date2= new Date(date2[2], date2[1] -1, date2[0]);
return date1 < date2 ? 1 : -1;
};
$(document).ready(function() {
$('#all_elements .element').sort(sortDescending).appendTo('#all_elements');
});
编辑 - 根据评论纠正错字!在这里摆弄http://jsfiddle.net/TsZeg/
答案 1 :(得分:0)
您是否尝试过日期对象:new Date($('.year').text())
?
答案 2 :(得分:0)
使用我的jquery插件SortContent:
$('#all_elements').sortContent({asc:true})
但是,由于您的排序基于String(Date)的不同内容,您应该使用format
回调。
并且,由于日期不是要排序的整个元素的HTML,您应该使用helper
回调来识别合适的内容。
$('div#all_elements').sortContent({format:parser,helper:myhelper})
必需的回调:
parser=function(content){
content=content.split('-');
//Convert 20-10-2011 to 10/20/2011 to be ready to Date parsing
content=content[1]+'/'+content[0]+'/'+content[2]
return Date.parse(content)
};
myhelper=function(e){
return $('.year',$(e)).html();
}
DEMO: