Besoin d'aide/de conseils sur la conversion d'une date ISO 8601 avec la structure suivante en javascript.
CCYY-MM-DDThh:mm:ssTZD
Je voudrais cadrer la date comme suit:
January 28, 2011 - 7:30PM EST
J'aimerais garder cette solution aussi propre et minimale que possible.
datejs pourrait analyser la suite, vous voudrez peut-être essayer.
Date.parse('1997-07-16T19:20:15') // ISO 8601 Formats
Date.parse('1997-07-16T19:20:30+01:00') // ISO 8601 with Timezone offset
Modifier: Version regex
x = "2011-01-28T19:30:00EST"
MM = ["January", "February","March","April","May","June","July","August","September","October","November", "December"]
xx = x.replace(
/(\d{4})-(\d{2})-(\d{2})T(\d{2}):(\d{2}):\d{2}(\w{3})/,
function($0,$1,$2,$3,$4,$5,$6){
return MM[$2-1]+" "+$3+", "+$1+" - "+$4%12+":"+$5+(+$4>12?"PM":"AM")+" "+$6
}
)
Résultat
January 28, 2011 - 7:30PM EST
Edit2: J'ai changé mon fuseau horaire en EST et maintenant j'ai suivi
x = "2011-01-28T19:30:00-05:00"
MM = {Jan:"January", Feb:"February", Mar:"March", Apr:"April", May:"May", Jun:"June", Jul:"July", Aug:"August", Sep:"September", Oct:"October", Nov:"November", Dec:"December"}
xx = String(new Date(x)).replace(
/\w{3} (\w{3}) (\d{2}) (\d{4}) (\d{2}):(\d{2}):[^(]+\(([A-Z]{3})\)/,
function($0,$1,$2,$3,$4,$5,$6){
return MM[$1]+" "+$2+", "+$3+" - "+$4%12+":"+$5+(+$4>12?"PM":"AM")+" "+$6
}
)
revenir
January 28, 2011 - 7:30PM EST
Fondamentalement
String(new Date(x))
revenir
Fri Jan 28 2011 19:30:00 GMT-0500 (EST)
regex parts juste convertir la chaîne ci-dessus au format requis.
January 28, 2011 - 7:30PM EST
L'objet Date gère 8601 comme premier paramètre:
var d = new Date("2014-04-07T13:58:10.104Z");
console.log(d.toString());
Si vous voulez rester simple, cela devrait suffire:
function parseIsoDatetime(dtstr) {
var dt = dtstr.split(/[: T-]/).map(parseFloat);
return new Date(dt[0], dt[1] - 1, dt[2], dt[3] || 0, dt[4] || 0, dt[5] || 0, 0);
}
note parseFloat est indispensable, parseInt ne fonctionne pas toujours. La carte nécessite IE9 ou une version ultérieure.
Fonctionne pour les formats:
Non valide pour les fuseaux horaires, consultez les autres réponses à ce sujet.
Vous pouvez peut-être utiliser moment.js qui, à mon avis, est la meilleure bibliothèque JavaScript pour analyser, formater et travailler avec les dates côté client. Vous pouvez utiliser quelque chose comme:
var momentDate = moment('1890-09-30T23:59:59+01:16:20', 'YYYY-MM-DDTHH:mm:ss+-HH:mm:ss');
var jsDate = momentDate.toDate();
// Now, you can run any JavaScript Date method
jsDate.toLocaleString();
L'avantage d'utiliser une bibliothèque comme moment.js est que votre code fonctionnera parfaitement même dans les navigateurs hérités comme IE 8+.
Voici la documentation sur les méthodes d'analyse: https://momentjs.com/docs/#/parsing/
Selon MSDN , l'objet JavaScript Date ne fournit aucune méthode de formatage de date spécifique (comme vous pouvez le voir avec d'autres langages de programmation). Cependant, vous pouvez utiliser quelques-unes des méthodes et du formatage Date
pour atteindre votre objectif:
function dateToString (date) {
// Use an array to format the month numbers
var months = [
"January",
"February",
"March",
...
];
// Use an object to format the timezone identifiers
var timeZones = {
"360": "EST",
...
};
var month = months[date.getMonth()];
var day = date.getDate();
var year = date.getFullYear();
var hours = date.getHours();
var minutes = date.getMinutes();
var time = (hours > 11 ? (hours - 11) : (hours + 1)) + ":" + minutes + (hours > 11 ? "PM" : "AM");
var timezone = timeZones[date.getTimezoneOffset()];
// Returns formatted date as string (e.g. January 28, 2011 - 7:30PM EST)
return month + " " + day + ", " + year + " - " + time + " " + timezone;
}
var date = new Date("2011-01-28T19:30:00-05:00");
alert(dateToString(date));
Vous pouvez même aller plus loin et remplacer la méthode Date.toString()
:
function dateToString () { // No date argument this time
// Use an array to format the month numbers
var months = [
"January",
"February",
"March",
...
];
// Use an object to format the timezone identifiers
var timeZones = {
"360": "EST",
...
};
var month = months[*this*.getMonth()];
var day = *this*.getDate();
var year = *this*.getFullYear();
var hours = *this*.getHours();
var minutes = *this*.getMinutes();
var time = (hours > 11 ? (hours - 11) : (hours + 1)) + ":" + minutes + (hours > 11 ? "PM" : "AM");
var timezone = timeZones[*this*.getTimezoneOffset()];
// Returns formatted date as string (e.g. January 28, 2011 - 7:30PM EST)
return month + " " + day + ", " + year + " - " + time + " " + timezone;
}
var date = new Date("2011-01-28T19:30:00-05:00");
Date.prototype.toString = dateToString;
alert(date.toString());