2010-12-06 8 views
1

Comment convertir ces chaînes pour le format de date et trier en conséquence .... s'il vous plaîtDate tri Javascript convertir par la chaîne pour le format de date

2010-11-08 18:58:50.0_getCreated_10180 
2010-11-09 17:49:42.0_getCreated_10180 
2010-11-09 17:49:42.0_getCreated_10180 
2010-11-24 19:44:51.0_getCreated_10180 
2010-11-09 13:54:46.0_getCreated_10180 
2010-11-23 20:06:29.0_getCreated_10180 
2010-11-23 20:06:04.0_getCreated_10180 
2010-11-15 17:51:37.0_getCreated_10180 

Merci à l'avance, Joseph

+0

Comment ces chaînes ont-elles été générées? –

Répondre

7

Si vous avez cela dans une seule chaîne alors faites.

// first create an array by splitting the string at the newlines 
var list = dateString.split('\n'); 
list = list 
    .map(// for each element in the list (each date) 
     function(val,idx){ 
      // use the first part(before the dot(.)), replace the - with spaces and convert to date 
      return new Date(val.split('.')[0].replace(/-/g,' ')); 
    }) 
    .sort(); // at the end sort the results. 

exemple à http://www.jsfiddle.net/gaby/rfGv8/


Ce que nous devons faire pour chaque date (ligne) est

2010-11-08 18:58:50 .0_getCreated_10180 (supprimer la pièce après le)
réalisé avec val.split('.')[0]

remplacez le - avec un espace pour le faire ressembler à 2010 11 08 18:58:50 qui est un format de date acceptable pour le constructeur Date.
accompli avec val.split('.')[0].replace(/-/g,' ')

passe ensuite comme paramètre au constructeur de date pour créer un objet Date
accompli avec new Date(val.split('.')[0].replace(/-/g,' '))

après l'application de ce qui précède à tous les éléments et obtenir un nouveau tableau utiliser la méthode .sort() pour trier le tableau dans l'ordre croissant.

+0

a aidé beaucoup ... merci –

0

Veuillez saisir le code suivant. La fonction getDateSort renvoie la date triée

<script language="javascript" type="text/javascript"> 

      function getDateSort() { 


       dateArray = new Array('2010-11-08 18:58:50', '2010-11-09 17:49:42', 
    '2010-11-09 17:49:42', '2010-11-15 17:51:37', '2010-11-23 20:06:04', '2010-11-09 13:54:46', '2010-11-23 20:06:29', '2010-11-24 19:44:51'); 
       dateArray.sort(dmyOrdA); 
       alert('Ascending : ' + dateArray + ''); 
       return false; 
      } 


      var dateRE = /^(\d{2})[\/\- ](\d{2})[\/\- ](\d{4})/; 
      function dmyOrdA(a, b) { 
       a = a.replace(dateRE, "$3$2$1"); 
       b = b.replace(dateRE, "$3$2$1"); 
       if (a > b) return 1; 
       if (a < b) return -1; 
       return 0; 
      } 
      function dmyOrdD(a, b) { 
       a = a.replace(dateRE, "$3$2$1"); 
       b = b.replace(dateRE, "$3$2$1"); 
       if (a > b) return -1; 
       if (a < b) return 1; 
       return 0; 
      } 
      function mdyOrdA(a, b) { 
       a = a.replace(dateRE, "$3$1$2"); 
       b = b.replace(dateRE, "$3$1$2"); 
       if (a > b) return 1; 
       if (a < b) return -1; 
       return 0; 
      } 
      function mdyOrdD(a, b) { 
       a = a.replace(dateRE, "$3$1$2"); 
       b = b.replace(dateRE, "$3$1$2"); 
       if (a > b) return -1; 
       if (a < b) return 1; 
       return 0; 
      } 

     </script> 
Questions connexes