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 :

$ dans le nom d'une variable


Sujet :

jQuery

  1. #1
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 21
    Points : 19
    Points
    19
    Par défaut $ dans le nom d'une variable
    Bonjour,

    Après avoir cherché sur le net, je ne comprends toujours pas la signification d'un tel code dans un fichier javascript (qui utilise JQuery) : base.$elem.width

    Que vient faire ici le $elem, plus précisément le $.
    Les seuls caractères autorisés pour les variables étant a-z A-Z 0-9 _ et &

    Voici un extrait du code :
    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
     
    (function ($, window, document) {
    ...
     calculateAll : function () {
                var base = this;
                base.calculateWidth();
                base.appendWrapperSizes();
                base.loops();
                base.max();
            },
     
    calculateWidth : function () {
                var base = this;
                base.itemWidth = Math.round(base.$elem.width() / base.options.items);
            },
    ...
    }(jQuery, window, document));
    Merci d'avance

  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 634
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 634
    Points : 66 650
    Points
    66 650
    Billets dans le blog
    1
    Par défaut
    Rien ...
    Il ne faut pas te laisser perturber par le $ dans le nom d'une variable ou d'une propriété

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $foo = "coucou";
    alert($foo)
    C'est un caractère comme un autre ...

    en général on nomme des variables qui représentent un élement du DOM en les commençant par un $, c'est une sorte de convention de nommage.

    http://jsfiddle.net/QAmqc/
    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
    Membre actif

    Profil pro
    Inscrit en
    Juillet 2012
    Messages
    183
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2012
    Messages : 183
    Points : 274
    Points
    274

  4. #4
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    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é : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Les seuls caractères autorisés pour les variables étant a-z A-Z 0-9 _ et &
    Pas en JavaScript en tout cas (voir : http://es5.github.io/x7.html#x7.6)

    $maVar pour nommer une variable est totalement valide.
    Par convention, les variables nommées ainsi qui sont des objets jQuery.

    Exemple : $monElem = $("#monElem");

  5. #5
    Rédacteur
    Avatar de marcha
    Homme Profil pro
    Développeur Web
    Inscrit en
    Décembre 2003
    Messages
    1 571
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Décembre 2003
    Messages : 1 571
    Points : 2 351
    Points
    2 351
    Par défaut
    Salut,

    Le caractère $ est un caractère légal pour le nom d'une variable en javascript.

    Par contre le & ne l'est pas.

    Plus d'info ici

    De par son aspect particulier, le $ est souvent utilisé par les librairies comme JQuery et sert
    généralement de référence à une instance de la librairie.

    Dans l'exemple que tu donnes, il y a une fonction englobante qui permet de passer librement
    des références de l'objet JQuery window et document en créant un scope, ce qui permet
    d'isoler le code et d'éviter des effets de bords. Explications ici

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    (function ($, window, document) {
    ...
    }(jQuery, window, document));
    Si ton code fait plus d'une ligne, c'est que tu as mal choisi ton langage !

  6. #6
    Membre à l'essai
    Inscrit en
    Mai 2006
    Messages
    21
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 21
    Points : 19
    Points
    19
    Par défaut Merci beaucoup.

  7. #7
    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 : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    Citation Envoyé par arnogues
    Tu te trompes


    Quel rapport avec le lien que tu donnes ? A part bien sûr le fait qu'il confirme que "$ est un caractère comme un autre" et tout à fait autorisé...

    Ensuite, si, Spaffy à raison : il est devenu assez courant chez beaucoup de développeurs de préfixer d'un $ les variables correspondant à un élément du DOM. Cette "convention" tire son origine de jQuery : de nombreux utilisateurs utilisaient cette convention pour différencier les objets jQuery et a été étendue aux variable représentant un élément du DOM.
    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

  8. #8
    Membre émérite
    Avatar de Kaamo
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    1 165
    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é : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 165
    Points : 2 778
    Points
    2 778
    Par défaut
    Je pense qu'arnogues s'adressait à F.Victoire et non à Spaffy. On a été 4 à répondre en même temps

  9. #9
    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 : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    Arf oui... Au temps pour moi, j'avais pas regardé les heures des réponses.
    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

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

Discussions similaires

  1. insérer une variable dans le nom d'une variable
    Par leninelenine dans le forum Général Python
    Réponses: 11
    Dernier message: 28/05/2015, 09h25
  2. tiret - dans le nom d'une variable javascript
    Par saraInfoSab dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 04/10/2013, 01h36
  3. Indice dans le nom d'une variable
    Par miko42 dans le forum MATLAB
    Réponses: 3
    Dernier message: 29/04/2008, 19h10
  4. Mettre le caractère % dans le nom d'une variable
    Par pelotudo dans le forum MATLAB
    Réponses: 3
    Dernier message: 03/04/2008, 18h20
  5. [RegEx] Caractères spéciaux dans le nom d'une variable
    Par Cartouche dans le forum Langage
    Réponses: 7
    Dernier message: 12/05/2007, 00h51

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