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 :

Vider le after() d'un élément.


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de hisy
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    377
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 377
    Par défaut Vider le after() d'un élément.
    Bonjour,

    Je m'intéresse depuis peu à jQuery et j'ai voulu créer un fonction d'affichage des erreurs dans un formulaire.

    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
    function error(elem,test,after){
    		// Ici quelque chose comme $("#" + elem).after().empty(), mais qui marche !
    		 if(test) {
    			$("#" + elem).animate( { borderLeftWidth:"10px", borderRightWidth:"10px" }, 500);
    			$("#" + elem).parent("p").css({borderLeft: '2px solid red'});
    			$("#" + elem).css({color: 'red'});
    			$("#" + elem).after().css({color: 'red'});
    			$("#" + elem).after("<br/>" + after);
    			setTimeout(function() { $("#"+ elem).focus()},500 );
    		 }
    		 else {
    			$("#" + elem).animate( { borderLeftWidth:"2px", borderRightWidth:"2px" }, 500);
    			$("#" + elem).parent("p").css({borderLeft: '0px'});
    			$("#" + elem).css({color: 'green'}); 
    		 }
    	}
    Cette fonction est appelée par d'autres qui vérifient certains critères sur les différents champs d'un formulaire. L'idée est de faire un petit effet visuel, à la saisie.
    Je suis plutôt satisfait du résultat mais je ne sais pas comment vider le message placé dans le after de l'élément quand la saisie est correcte.

    Merci pour votre aide et vos remarques.

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    empty() ?
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    after() n'est pas un sélecteur... il permet juste d'ajouter du contenu après les éléments de la collection en cours, tu ne peux donc pas l'utiliser pour cibler un élément (et l'utiliser sans paramètre n'a pas vraiment de sens).
    La solution serait d'englober tout le contenu à intégrer dans une balise avec un id et de faire un empty() sur cette balise.
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  4. #4
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 659
    Billets dans le blog
    1
    Par défaut
    c'est next() le selecteur
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  5. #5
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Citation Envoyé par SpaceFrog
    c'est next() le selecteur
    Tout à fait
    Sauf que là, ça ne sera pas satisfaisant vu le code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("#" + elem).after("<br/>" + after);
    qui va donc probablement générer plusieurs éléments (si le paramètre after contient des balises) et en tout état de cause, next() référencera le <br />, pas le reste, d'où l'utilité d'englober tout ça gentiment dans une div, qui permet de se passer du <br /> et de récupérer l'ensemble de ce qui a été ajouté avec next().
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  6. #6
    Membre éclairé Avatar de hisy
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    377
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Novembre 2004
    Messages : 377
    Par défaut
    He ben merci merci pour toutes ces infos ...

    On le dit pas assez mais si l'informatique progresse si vite aujourd'hui c'est grâce à des forums comme celui-ci qui nous évite de perdre des heures ...

    Merci

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

Discussions similaires

  1. Pseudo-élément after pour un lien
    Par NeraOne dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 10/08/2011, 08h05
  2. after sur un élément déjà ramené par un after
    Par Papy214 dans le forum jQuery
    Réponses: 4
    Dernier message: 31/08/2010, 17h07
  3. Pseudo éléments :before et :after sous IE
    Par _jey_ dans le forum Mise en page CSS
    Réponses: 5
    Dernier message: 14/05/2009, 16h56
  4. Pointer sur un élément implémenté par JS, vider le cache
    Par descurai dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 11/05/2009, 16h33
  5. [vector] "vider" un vecteur de un élément ?
    Par Deneteth dans le forum SL & STL
    Réponses: 5
    Dernier message: 01/04/2009, 23h50

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