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 :

Récupérer les coordonnées de plusieurs DIV dans une boucle PHP


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Par défaut Récupérer les coordonnées de plusieurs DIV dans une boucle PHP
    Bonjour à tous,

    Une boucle PHP lit une table et affiche des images avec liens. Je voudrais que ces liens affichent une petite popup d'info en DHTML.

    L'ennui c'est que la liste peut être longue et nécessiter les scrolls du navig. Résultat : si j'affiche la popup depuis une des lignes du bas, elle n'est plus visible !

    Je dois donc régler le style.top. Oui, mais comme on est dans une boucle, le "top" est variable. J'ai donc eu l'idée de récupérer la coordonnée Y de chaque image et de la passer en paramètre dans la fonction d'ouverture de popup.

    Dans la boucle PHP

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    $i = 0;
    while($row = mysql_fetch_assoc($sql)){
     echo '<div id="image'.$i.'"></div><img src="image.gif" onclick="cherche_coords('"image".$i."')"'>
    $i++;
    }
    Et côté JS

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    function cherche_coords(obj) {
    	var curleft = curtop = 0;
    		if (obj.offsetParent) {
    			do {
    			curleft = obj.offsetLeft;
    			curtop = obj.offsetTop;
    			} while (obj = obj.offsetParent);
    		}
    document.getElementById("test").innerHTML = curtop;
    return [curleft,curtop];
    }
    Mais ça retourne toujours 0.
    Quelqu'un peut m'aider ?
    Merci à lui.

  2. #2
    Membre Expert
    Avatar de emmanuel.remy
    Inscrit en
    Novembre 2005
    Messages
    2 855
    Détails du profil
    Informations personnelles :
    Âge : 56

    Informations forums :
    Inscription : Novembre 2005
    Messages : 2 855

  3. #3
    Membre éprouvé Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Par défaut
    Bonjour et merci, effectivement, c'est tout à fait ce qu'il me fallait.

    Avant que je ne passe ce post en résolu, j'aurais un petit souci à soumettre : comment faire apparaître des sauts de ligne dans le popup ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $text_a_afficher = "ceci est le texte que je veux afficher et ICI \n je voudrais un saut de ligne";
    echo "<a href='#' onclick=\"affiche_popup('".$text_a_afficher."') \">";
    Dans le JS, c'est un simple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    document.getElementById("contentArea").innerHTML = content;
    //ou (mais le résultat est le même)
    document.getElementById("contentArea").firstChild.data = content;
    J'ai essayé avec <br> : ça s'affiche en clair.
    Avec \\n : pas de saut de ligne. idem avec \r\n
    J'ai essayé simple quote, double quote... soit ça ne fait rien du tout, soit la console FF sort "unterminated string literal".

    Tu aurais une idée sur la question ?
    Je t'en remercie d'avance.

  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
    en HTML le saut de ligne c'est <br/> pas \n
    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
    Membre éprouvé Avatar de renaud26
    Homme Profil pro
    Webmaster
    Inscrit en
    Mars 2003
    Messages
    1 365
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Webmaster

    Informations forums :
    Inscription : Mars 2003
    Messages : 1 365
    Par défaut
    Bonjour, oui je n'en doute pas une seconde...
    Mais <br/> s'affiche en clair dans le popup et ne provoque pas de saut de ligne.

Discussions similaires

  1. copier plusieurs champs dans une boucle php avec javascript
    Par groskanel dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 05/08/2010, 14h47
  2. Récupérer les données de 2 tableaux dans une boucle
    Par poleta77 dans le forum Langage
    Réponses: 6
    Dernier message: 21/12/2009, 15h41
  3. Récupérer les coordonnées d'un pixel dans une image
    Par amine52002 dans le forum Langage
    Réponses: 1
    Dernier message: 30/06/2008, 14h52
  4. Comment récupérer les coordonnées sur le bureau d'une form ?
    Par fma2112 dans le forum API, COM et SDKs
    Réponses: 2
    Dernier message: 22/02/2006, 23h43
  5. Récupérer les valeur d'un énuméré dans une string
    Par Oliv_75 dans le forum SL & STL
    Réponses: 5
    Dernier message: 28/09/2005, 00h55

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