【问题标题】:How to sort div's by content date如何按内容日期对div进行排序
【发布时间】:2011-12-06 05:24:27
【问题描述】:

我正在尝试按内容日期对 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>

我知道我需要一个函数来确定内容是日期.. 就是不知道怎么...

谁能帮帮我?

【问题讨论】:

标签: jquery sorting date html


【解决方案1】:

您是否尝试过日期对象:new Date($('.year').text())

【讨论】:

  • 好吧,是的,如果您的计算机知道您处理的是非美国日期格式。
  • 完全正确;你必须把它硬塞进去。
【解决方案2】:

你可以这样做:

   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,我为你做了这个:jsfiddle.net/TsZeg,你在第二次约会中有错字 $(b) 而不是 $(a)​​
  • 感谢您的提琴和发现错字! :)
  • 如果要支持日期和时间,还需要进行哪些更改?
  • 对不起,答案很简单,只是把新日期的时间告诉你
  • 升序使用 return date1 > date2 ? 1 : -1;
【解决方案3】:

使用我的 jquery 插件 SortContent :

$('#all_elements').sortContent({asc:true})

但是,由于您的排序基于与 String (Date) 不同的东西,您应该使用 format 回调。 而且,由于 Date 不是要排序的元素的整个 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();
}

演示:

http://jsfiddle.net/abdennour/E4Hbp/8/

【讨论】:

    猜你喜欢
    • 2012-02-22
    • 1970-01-01
    • 1970-01-01
    • 2015-06-30
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多