001 -js對時間日期的排序


001-JS對時間日期的排序

最近在做公司的項目時間,產品給了一個很簡單的頁面,讓幫忙寫一下。首先看一下產品的需求:

   需要對該列表進行排序

   思路:(1)可以在數據庫寫sql語句的時間直接一個DESC按照時間降序排序就OK

           (2)也可以是Controller控制器里面對List集合做一個遍歷,然后時間進行比較

           (3)當然,也可以在頁面JS按照時間進行排序

-----------------------------------------------------------華麗的分割線-----------------------------------------------------------------------------------------

       JS對時間進行排序如果進行的?

     (1)sort函數的使用【現在只討論如果使用,至於更深的原理和用法,本人小白,還沒有研究

              

 

       controller層返回到前台頁面的是一個List集合,

         (1)首先需要獲取到所有的集合對象

       (2)sort函數對集合中的按照某一個字段進行排序

     

 1 function datagridBind() {
 2     $("#dg").datagrid("loading");
 3     $.get("reconResultStatisticsList.htm",      $("#formSearch").serialize(), function(pager){
//按照時間的大小進行排序 降序
4 var rows = pager.pageData; 5 rows.sort(function (a, b) { 6 return a.reconDate<b.reconDate?1:-1; 7 }); 8 $("#dg").datagrid("loadData", {"total":pager.total, rows:rows}); 9 $("#dg").datagrid("loaded"); 10 }); 11 }

這樣就可以完成排序!

 ---------------------------------------------------------sort()函數的說明------------------------------------------------------------------------------------------------------------------

如果調用該方法時沒有使用參數,將按字母順序對數組中的元素進行排序,說得更精確點,是按照字符編碼的順序進行排序。要實現這一點,首先應把數組的元素都轉換成字符串(如有必要),以便進行比較。

array.sort()方法默認是升序排序,如果想按照其他標准進行排序,就需要提供比較函數,該函數要比較兩個值,然后返回一個用於說明這兩個值的相對順序的數字。比較函數應該具有兩個參數 a 和 b,其返回值如下:

  • 若 a 小於 b,在排序后的數組中 a 應該出現在 b 之前,則返回一個小於 0 的值。
  • 若 a 等於 b,則返回 0。
  • 若 a 大於 b,則返回一個大於 0 的值。

 

  參考文章:

   https://blog.csdn.net/u013022210/article/details/51995409

   https://www.cnblogs.com/saifei/p/9043821.html

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM