IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèques & Frameworks Discussion :

Moment.js : convertir les dates au format local vers un format datetime


Sujet :

Bibliothèques & Frameworks

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut Moment.js : convertir les dates au format local vers un format datetime
    Bonjour à tous,

    Hier, je me suis mis à l'étude et à l'utilisation de moment.js afin de préparer mon futur site à une internationalisation.

    Donc, dans un premier temps, j'affiche les date au format local en procédant en 2 temps : au niveau du datepicker, j'applique le format 'yyyy-mm-dd' et au niveau de l'input et ensuite, lors de la détection d'un changement au niveau de l'input, j'applique le format local.

    Voici le code concerné pour ces deux opérations :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
        $([document]).on('focus', 'input.js-datepicker-period',function() {
     
            $(".js-datepicker-period").datepicker({
                viewMode: "months",
                weekStart: 1,
                daysOfWeekHighlighted: "6,0",
                autoclose: true,
                todayHighlight: true,
                startDate: '-0m',
                endDate:'+2y',
                format: 'yyyy-mm-dd'
            });
     
        });
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
        $([document]).on('change', 'input.js-datepicker-period',function() {
     
            $(this).val(moment($(this).val(), 'YYYY-MM-DD').locale(navigator.language).format('L'));
     
        });
    Mon problème est le suivant : en base de données, le champ accueillant la date est de type datetime. Donc, au moment de l'envoi du formulaire, je devrais pouvoir détecter la locale de l'utilisateur et transformer les dates au format 'YYYY:mm:dd 00:00:00', du genre :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
        $("form").submit(function(event) {
    
            $('input.js-datepicker-period').each(function(e) {
    
                $(this).val(moment($(this).val(), 'locale_format').convertToDatetime());
    
            });
    
        });
    Cependant, je ne sais pas comment effectuer ceci.

    Quelqu'un aurait une idée?

    Merci d'avance pour votre aide.

  2. #2
    Membre averti
    Homme Profil pro
    Inscrit en
    Mai 2004
    Messages
    803
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 803
    Points : 356
    Points
    356
    Par défaut
    J'ai résolu mon problème de la façon suivante :

    - au niveau de mon app.js (main.js) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    import moment from 'moment';
    window['moment'] = moment;
    moment.locale(navigator.language);
    - au niveau du dateTimePicker:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
     
        $([document]).on('focus', 'input.js-datepicker-period',function() {
     
            $(".js-datepicker-period").datepicker({
                viewMode: "months",
                weekStart: 1,
                daysOfWeekHighlighted: "6,0",
                autoclose: true,
                todayHighlight: true,
                startDate: '-0m',
                endDate:'+2y',
                format: 'yyyy-mm-dd'
            });
     
        });
    - au niveau de la valeur des inputs :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
     
    ...
    moment.locale(navigator.language);
    var localData = moment.localeData();
    var localeDateFormat = localData['_longDateFormat']['L'];
    ...
        //Dates formatting according user's locale
        $('input.js-datepicker-period').each(function () {
     
            var sDate = $(this).val();
     
            $(this).val(moment(sDate, 'YYYY-MM-DD').format('L'));
     
        });
        //End date formatting
    ...
        $([document]).on('change', 'input.js-datepicker-period',function() {
     
            $(this).val(moment($(this).val(), 'YYYY-MM-DD').format('L'));
     
        });
     
        $("form").submit(function(event) {
     
            $('input.js-datepicker-period').each(function(e) {
     
                var sDate = $(this).val();
                var dateTime = moment(sDate, localeDateFormat).toISOString();
     
                $(this).val(dateTime);
     
            });
     
        });

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. afficher toutes les dates au format francais
    Par msteinbe dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 23/12/2007, 22h19
  2. [SQL] Convertir les dates us en fr
    Par shllolo dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 22/09/2007, 14h12
  3. Réponses: 8
    Dernier message: 26/04/2007, 17h24
  4. Pour convertir les dates aux types "datetime" sous
    Par nnn2050 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 04/01/2006, 15h30
  5. Convertir une date au format excel en datetime SQL server
    Par ALLB dans le forum MS SQL Server
    Réponses: 8
    Dernier message: 20/07/2004, 11h28

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo