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 :

De la portée de $(this)


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    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 De la portée de $(this)
    En voulait incrementer le z-index d'objets je suis tombé sur ceci que je ne comprends pas :

    Un bout de code qui plante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    console.log(elt);  
    $("#"+elt).css("z-index",$(this).css('z-index')+1)
    console.log($("#"+elt).css("z-index"));
    Un bout de code qui fonctionne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    console.log(elt);  
    $("#"+elt).css("z-index",$('#'+elt).css('z-index')+1)
    console.log($("#"+elt).css("z-index"));
    ou
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    console.log(elt);  
    z=$("#"+elt).css("z-index")+1
    $("#"+elt).css("z-index",z)
    console.log($("#"+elt).css("z-index"));
    pourquoi le $(this) ne passe-t-il pas dans le css() .
    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 !

  2. #2
    Membre éclairé Avatar de arthuro45
    Profil pro
    Développeur du dimanche
    Inscrit en
    Juillet 2009
    Messages
    602
    Détails du profil
    Informations personnelles :
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur du dimanche

    Informations forums :
    Inscription : Juillet 2009
    Messages : 602
    Par défaut
    Avec mon tout petit niveau, allez j'ose
    peut-être comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $("#"+elt).css("z-index", $("#"+this).css('z-index')+1)

  3. #3
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par défaut
    Bonjour,
    je dirais qu'il faut récupérer la valeur...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $('#' +elt).css('z-index', function(){
      return ($(this).css('z-index')*1) +1;
    });

  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


    retourner le z-index ??

    Ben ce n'est pas ce qu'est supposé faire

    ???
    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 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
    Citation Envoyé par SpaceFrog Voir le message
    En voulait incrementer le z-index d'objets je suis tombé sur ceci que je ne comprends pas :

    Un bout de code qui plante
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    console.log(elt);  
    $("#"+elt).css("z-index",$(this).css('z-index')+1)
    console.log($("#"+elt).css("z-index"));
    pourquoi le $(this) ne passe-t-il pas dans le css() .
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $(function(){
    	var elt = "divID";
     
    	console.log( elt );
     
    	// ici this c'est le document
    	$( "#" + elt ).css( "z-index" , $( console.log( this ) ).css( 'z-index' ) + 1 );
     
    	console.log( $( "#" + elt ).css( "z-index" ) );
    });

    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
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 211
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 211
    Par défaut
    Dans ta syntaxe le $(this) est évalué avant que son résultat ne soit transmis comme argument ce qui fait qu'au moment de l'évaluation le this représente le DOMWindow.

    En utilisant la fonction anonyme celle ci est transmise comme argument à la 2éme méthode .css.

    Avec une analyse, en mode pas à pas, on retrouve bien la fonction anonyme dans le coeur du code jQuery en tant qu'argument dans la fonction jQuery.fn.css.

    Dans ta syntaxe les 2 $(xx) sont d'abord évalués, la fonction anonyme, donc le $(this), quant à elle n'étant exécutée qu'au coeur de la méthode .css.

  7. #7
    Membre expérimenté Avatar de eckerdecker
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    134
    Détails du profil
    Informations personnelles :
    Âge : 40
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 134
    Par défaut
    Sans offense aucune, c'est le même problème que dans le sujet suivant
    http://www.developpez.net/forums/d11...tee-this-load/

  8. #8
    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
    Ha, j'avais oublié ce souci sur le load ...

    Je trouve vraiment volatile le this en js
    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 !

  9. #9
    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

    Volatile ? Je ne pense pas ! Déroutant, difficile à apprivoiser, souvent déconcertant ? J'approuve !

    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. [Débutant] Borland C++ Builder : Portée du this, fonctions dans un formulaire, et espions
    Par otacon ghost dans le forum C++Builder
    Réponses: 3
    Dernier message: 20/07/2011, 15h32
  2. [Dojo] Portée de "this" dans une fonction
    Par Zineb1987_UNI dans le forum Bibliothèques & Frameworks
    Réponses: 8
    Dernier message: 21/12/2009, 17h08
  3. portée de THIS en paramètre de fonction
    Par backnight dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 12/10/2009, 09h40
  4. [Prototype] Portée de this dans une classe
    Par grunk dans le forum Bibliothèques & Frameworks
    Réponses: 2
    Dernier message: 07/04/2009, 14h58
  5. [DOM] portée de "this"
    Par Finidrigoler dans le forum Général JavaScript
    Réponses: 22
    Dernier message: 06/07/2007, 18h56

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