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

jQuery Discussion :

Test de validité avant soumission


Sujet :

jQuery

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 420
    Par défaut Test de validité avant soumission
    Bonjour a tous,

    J'aurai besoin de votre aide concernant la validation d'un formulaire.

    Dans un formulaire je récupère des informations issu de ma BDD (MySQL). Pour les afficher dans mes champs de saisie j'utilise value dans mon input

    voici le code d'un des champs au complet

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    <input id="datePrelevement" name="datePrelevement" type="text"  class="input-xlarge datepicker"
                               value="<?php echo date($_POST['datePrelevement']) ?> " />
    Pour faire les vérifications dans le formulaire (requis, date, longueur de la saisie) j'utilise le plugin JQery validity

    http://validity.thatscaptaintoyou.com/

    Le problème c'est que les champs ayant une valeur pour value me retourne une erreur de validation



    Comment faire pour contourner ce problème s'il vous plait ? car j'ai ce soucis sur le champ de la date, et deux autres champs sur lesquels je regarde la longueur de la chaîne de caractère saisie

    Je vous remercie par avance pour votre aide

  2. #2
    Membre très actif Avatar de demenvil
    Homme Profil pro
    Analyste développeur
    Inscrit en
    Avril 2009
    Messages
    195
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Analyste développeur
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2009
    Messages : 195
    Par défaut
    Peut être le format de la date ?
    Il attend peut être un format anglais : 2013/11/26 ?

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 420
    Par défaut
    salut,

    Le champs date est un datepicker et lorsque je clique sur le calendrier c'est ce format là que j'affiche et la validation se fait très bien.

  4. #4
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 420
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 420
    Par défaut
    C'est pas plutôt l'utilisation du module de validation javascript qui pose problème ? Si oui cela n'a pas grand chose à voir avec php et dans ce cas tu aurais plus de réponse dans un forum plus adapté (javascript/jquery).

  5. #5
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut
    date : Will only match dates in the American mm/dd/yyyy format. To support other date formats refer to the Internationalization Section later on in this document.

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  6. #6
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 420
    Par défaut
    J'avais déjà modifié l'expression régulière pour la mettre au format français, et le problème de ne se produit pas lorsque je saisie la date mais uniquement lors que je rappelle la valeur depuis ma BDD pour l'afficher dans le champs pour qu'elle puisse être éventuellement modifier par l'utilisateur.

    Par contre j'ai peut être une piste, bien que j'ai mis la fonction TRIM à l'enregistrement, il semblerai qu'à l'affichage il m'ajout quelque caractère "espace" en fin de chaine.
    Pour une zone de saisie qui elle aussi me pose problème j'ai 6 caractère d'afficher et si je fait un len($chaine) j'ai 7 en retour.

    J'ai donc modifier comme ceci

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <div class="controls">
        <input id="datePrelevement" name="datePrelevement" type="text"  class="input-xlarge datepicker"
        value="<?php echo trim($_POST['datePrelevement']) ?>" />
    </div>

    Mais malgré ça il me flanque toujours des caractères en plus en fin de chaine

  7. #7
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 420
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 420
    Par défaut
    Dans une bdd le format DATE est au format yyyy-mm-dd. Il faut donc le convertir avant de le mettre dans ton champ utilisateur puisque selon danielhagnoul le validateur ne supporte que le format mm/dd/yyyy (et non pas dd/mm/yyyy comme dans ton exemple en français).

  8. #8
    Membre expérimenté
    Profil pro
    Responsable de service informatique
    Inscrit en
    Août 2006
    Messages
    174
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Responsable de service informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2006
    Messages : 174
    Par défaut
    Bonsoir,

    Pour moi il manque un ; dans ton echo.

    Ensuite pour ton problème de date, tout a été dit.

    Cordialement,

    Natso

  9. #9
    Membre éclairé
    Profil pro
    Inscrit en
    Janvier 2005
    Messages
    420
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2005
    Messages : 420
    Par défaut
    Citation Envoyé par ABCIWEB Voir le message
    Dans une bdd le format DATE est au format yyyy-mm-dd. Il faut donc le convertir avant de le mettre dans ton champ utilisateur puisque selon danielhagnoul le validateur ne supporte que le format mm/dd/yyyy (et non pas dd/mm/yyyy comme dans ton exemple en français).
    Salut,
    Dans la base de donnée la date est enregistré en format string et non pas au format Date, justement a cause du format.
    Après le problème qu'il ne supporte pas le format français, je ne pense pas que ça soit ça le problème, puisque lorsque je sélectionne une date dans le datePicker l'affichage est en format français et lors de la soumission du formulaire tout se déroule correctement.
    Le problème c'est lorsque je rappelle la valeur et que je l'affiche avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    value="<?php echo trim($_POST['datePrelevement']); ?>"
    que ça coince et si je retape la date au clavier ou si je la reselectionne dans le datepicker ça passe nickel

  10. #10
    Expert confirmé

    Homme Profil pro
    Développeur Web
    Inscrit en
    Septembre 2010
    Messages
    5 420
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Septembre 2010
    Messages : 5 420
    Par défaut
    Tu devrais tester ta variable avant de l'afficher, par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    value="<?php echo isset($_POST['datePrelevement']) ? trim($_POST['datePrelevement']) : ''; ?>"
    Sinon ce n'est pas une bonne idée d'avoir une date au format string dans ta bdd. Tu te prive ainsi de toute la panoplie des fonctions mysql pour faire des recherche dans cette colonne. La procédure habituelle est d'enregistrer au format DATE et de faire la conversion au format souhaité pour l'affichage ou autres traitements.

  11. #11
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Billets dans le blog
    125
    Par défaut
    Bonsoir

    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    <input id="datePrelevement" name="datePrelevement" type="text"  class="input-xlarge datepicker"
        value="<?php echo trim($_POST['datePrelevement']) ?>" />

    Vous donnez une valeur à l'attribut "value" dans PHP, mais coté client lors de l'initialisation de la page le champ texte de l'input "datePrelevement" est-il rempli avec la bonne date ?

    S'il est vide, il faut aussi faire un $( "#datePrelevement" ).text( "28/11/2013" ); (remplacer par la date souhaitée) lorsque le DOM est "ready".

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

Discussions similaires

  1. [Sécurité] Traitement préventif ou test de validité ?
    Par php_de_travers dans le forum Langage
    Réponses: 3
    Dernier message: 20/05/2006, 15h11
  2. Test de validité d'une adresse mail
    Par abigaelle dans le forum Réseau/Web
    Réponses: 3
    Dernier message: 11/05/2006, 11h18
  3. formulaire et concaténation type="text" avant soumission
    Par jakouz dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 22/04/2006, 11h39
  4. [debutant][bean] test de validité d'un champs
    Par LoLoSS dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 20/05/2004, 13h16

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