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

JavaScript Discussion :

Connaître l'index d'une valeur dans un tableau


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 82
    Points : 60
    Points
    60
    Par défaut Connaître l'index d'une valeur dans un tableau
    Bonjour,

    J'aimerais pouvoir stocker dans une variable l'index d'une valeur d'un tableau.

    Exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var tab = ["a", "b", "c", "d"];
    Si le tableau contient, par exemple, une liste d'images, je sais que je pourrais faire :

    this.src;
    Ça va me retourner l'src de l'image sur laquelle je clique. Si j'aurais fais "this.id" ça m'aurait retourner l'id de l'image. Mais si je veux qu'on me retourne la position de cette image dans le tableau (si elle est dans l'index 0, 1, ou 2...), comment faire ? Est ce qu'il existe un "this.index" ?

    Comment faire pour stocker dans une variable la position de l'élément du tableau sur lequel on vient de cliquer ?

    Merci.

  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 640
    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 640
    Points : 66 669
    Points
    66 669
    Billets dans le blog
    1
    Par défaut
    Cela suppose l'unicité de tes éléments d'array... ou alors ton arrayIndex devra retourner un tableau

    Mais on peut imaginer un prototype du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Array.prototype.arrayIndex=function(valeur){
    var i=-1;
    var indexes = new Array();
    while (this[++i]){
    	if (this[i]===valeur){
    		indexes.push(i);}
     }
    return (indexes.length>0)? indexes:-1;
    }		
     
    var tab = ["a", "b", "c", "d","b"];
     
    alert(tab.arrayIndex('b'))
    retourne un tableau des indexes correspondants à la valeur recherchée, ou -1 si pas d'occurrences
    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 : 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 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    A noter qu'il existe aussi la méthode indexOf() pour les array, mais elle n'est pas compatible IE
    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
    Expert confirmé
    Avatar de RomainVALERI
    Homme Profil pro
    POOête
    Inscrit en
    Avril 2008
    Messages
    2 652
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Meurthe et Moselle (Lorraine)

    Informations professionnelles :
    Activité : POOête

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 652
    Points : 4 164
    Points
    4 164
    Par défaut
    Citation Envoyé par Bovino Voir le message
    A noter qu'il existe aussi la méthode indexOf() pour les array, mais elle n'est pas compatible IE
    ...auquel cas on peut également la redéfinir en s'inspirant par exemple de Prototype ^^
    (c'est ce que j'ai fait de mon côté suite je crois à un conseil de vermine )

    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    // rustine tirée de Prototype (merci les gars ^_^') pour assurer Array.indexOf dans IE
    if (!Array.prototype.indexOf) Array.prototype.indexOf = function(item, i) {
      i || (i = 0);
      var length = this.length;
      if (i < 0) i = length + i;
      for (; i < length; i++)
        if (this[i] === item) return i;
      return -1;
    }

    ...pour les linguistes et les curieux >>> générateur de phrases aléatoires

    __________________

  5. #5
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 048
    Points : 44 562
    Points
    44 562
    Par défaut
    on peut également passer par les tableaux associatifs
    petit exemple pour illustrer
    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
    <html>
    <head>
    </head>
    <body>
      <img src="img/image1.jpg">
      <img src="img/image2.jpg">
      <img src="img/image3.jpg">
      <img src="img/image4.jpg">
    </body>
    <script type="text/javascript">
    // le tableau 
    var tImage = [];
    // la fonction de lecture
    function getIndex( tab, ref){
      return tab[ ref] ? tab[ ref] :-1;
    }
    // la recuperation et initialisation
    for( var i=0, nb =document.images.length; i < nb; i++){
      var oImg = document.images[i];
      // affectation
      tImage[oImg.src] = i+1;
      // fct sur click pour voir
      oImg.onclick = function(){
         alert( 'image n° ' +getIndex( tImage, this.src));
      }
    }
    </script>
    </html>
    à condition de l'avoir initialisé au paravent.

  6. #6
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    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
    <script type="text/javascript">
     
    var tab = ["un", "deux", "trois", "quatre","cinq"];
     
    function cherch(n){
    	for(i in tab){
    		if(tab[i]==n){
    			alert(n + "\n\na été trouvé à l'index " + i + " du tableau");break;
    		}
    	}
    }
     
    cherch("trois");
     
    </script>

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 82
    Points : 60
    Points
    60
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    Cela suppose l'unicité de tes éléments d'array... ou alors ton arrayIndex devra retourner un tableau

    Mais on peut imaginer un prototype du genre:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Array.prototype.arrayIndex=function(valeur){
    var i=-1;
    var indexes = new Array();
    while (this[++i]){
    	if (this[i]===valeur){
    		indexes.push(i);}
     }
    return (indexes.length>0)? indexes:-1;
    }		
     
    var tab = ["a", "b", "c", "d","b"];
     
    alert(tab.arrayIndex('b'))
    retourne un tableau des indexes correspondants à la valeur recherchée, ou -1 si pas d'occurrences
    Merci !

    Par contre, ça ne marche pas sur mon script...

    J'ai un tableau qui se nomme cibleImg et qui contient pleins d'images.

    Quand je fais this.src, je reçois le chemin de l'image sur lequel j'ai cliqué.

    Mais quand j'utilise ta fonction et fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alert(cibleImg.arrayIndex(this.src))
    Le script ne fonctionne plus.

  8. #8
    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 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Peut être que cibleImg n'est pas vraiment un tableau.
    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

  9. #9
    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 640
    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 640
    Points : 66 669
    Points
    66 669
    Billets dans le blog
    1
    Par défaut
    à condition de l'avoir initialisé au paravent.
    pour se planquer derrière ??
    ne pas confondre auparavant et un paravent

    array, objet collection ...
    on peut le voir ce mystérieux objet ?
    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 !

  10. #10
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 048
    Points : 44 562
    Points
    44 562
    Par défaut
    Citation Envoyé par SpaceFrog
    pour se planquer derrière ??
    ne pas confondre auparavant et un paravent
    on eut pu croire à de l'humour, mais il n'en est rien c'est bien une coquille...

    Concernant le sujet traité, il y a encore la possibilité d'utiliser l'attribut tabIndex, même si non valide W3C, celui ci étant supporté sur les IMG par les navigateurs.

    Le script que j'ai proposé devenant
    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
    // le tableau 
    var tImage = [];
    // la fonction de lecture
    function getIndex( tab, ref){
      return tab[ ref] ? tab[ ref] :-1;
    }
    // la recuperation et initialisation
    for( var i=0, nb =document.images.length; i < nb; i++){
      var oImg = document.images[i];
      var index = i+1;
      // affectation
      tImage[oImg.src] = index;
      // ajout tabindex
      oImg.setAttribute('tabIndex', index);
      // fct sur click pour voir
      oImg.onclick = function(){
         alert( 'image n° ' +getIndex( tImage, this.src) +'\ntabIndex : ' +this.getAttribute('tabIndex'));
      }
    }
    par exemple

  11. #11
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    82
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 82
    Points : 60
    Points
    60
    Par défaut
    Merci !

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 16/07/2014, 09h40
  2. Récupérer l'index d'une valeur dans un ndArray
    Par quedreuxa dans le forum Général Python
    Réponses: 3
    Dernier message: 18/06/2010, 17h00
  3. Réponses: 9
    Dernier message: 05/01/2007, 20h04
  4. Rechercher une valeur dans un tableau
    Par pafi76 dans le forum Access
    Réponses: 2
    Dernier message: 29/06/2006, 14h23
  5. Réponses: 21
    Dernier message: 28/02/2006, 15h23

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