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 :

Translation horizontale par rapport à la position d'une autre div


Sujet :

JavaScript

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Juin 2012
    Messages
    1
    Détails du profil
    Informations forums :
    Inscription : Juin 2012
    Messages : 1
    Points : 1
    Points
    1
    Par défaut Translation horizontale par rapport à la position d'une autre div
    Bonjour à tous,

    Voilà je souhaite réaliser un menu horizontal avec une petite icône juste en dessous du menu qui, lorsque je clique sur un des liens du menu, se déplace pour venir se placer en dessous du lien cliqué. Je vous joins une copie d'écran pour que vous compreniez mieux: sur l'image l'icône est en dessous de l'onglet "welcome", et si je clique sur "our work" par exemple je veux que l'icône se déplace sous cet onglet.

    menu

    Je sais comment faire une translation en javascript en partant d'une position définie en pixel jusqu'à une autre position définie en pixel. Pour l'instant voici mon 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
     
    function move() {
     
      var left = 300
     
      function frame() {
     
        left++  
        document.getElementById('small-icon').style.left = left + 'px' 
        if (left == 400) 
          clearInterval(id)
      }
     
      var id = setInterval(frame, 10) 
    }
    Le problème c'est que mon menu n'a pas une position fixe vu que je veux qu'il soit en permanence centrée quelque soit la taille de la fenêtre, la position des onglets en pixels n'est donc pas fixe.

    Je voudrais donc savoir s'il est possible de dire en javascript: position (abscisse) de départ de mon icône = abscisse de l'onglet "welcome"; position d'arrivée = position de l'onglet "our work".

    J'espère avoir été clair, n'hésitez à me demander des précisions si ce n'est pas le cas.

    Merci d'avance pour votre aide

  2. #2
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    Salut,

    J'ai une fonction qui te renvoie la position d'un objet dont tu connais l'id...
    Peut-être que cela peut t'aider/
    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
    29
    30
    31
    32
    33
    jQuery.fn.extend({
       findPos : function() {
           obj = jQuery(this).get(0);
           var curleft = (obj.offsetLeft-obj.scrollLeft) || 0;
           var curtop = (obj.offsetTop-obj.scrollTop) || 0;
           while (obj = obj.offsetParent) {
                    curleft += (obj.offsetLeft-obj.scrollLeft)
                    curtop += (obj.offsetTop-obj.scrollTop)
           }
           return {x:curleft,y:curtop};
       }
    });
     
     
     
    function positiongeneralx(nomappli)
    {
    var position=new Object;
     
    position = $('#'+nomappli).findPos();
     
    return position.x;
    }
     
     
    function positiongeneraly(nomappli)
    {
    var position=new Object;
     
    position = $('#'+nomappli).findPos();
     
    return position.y;
    }
    Les deux dernières fonctions peuvent être réuni en une (qui te renverra un object position.
    Il te faut JQUERY pour faire marcher ces fonctions.
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

  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
    Mouais... enfin, tu peux faire plus simple avec .position(), .scrollTop() et .scrollLeft()
    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
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    Mouais... enfin, tu peux faire plus simple avec .position(), .scrollTop() et .scrollLeft()
    Ah, je savais pas...
    D'un coup, ma fonction est moins intéressante, je savais pas qu'il y avait des fonctions toutes faites qui te renvoyait la position absolute dans le body de la page top (index quoi)...récursive en fonction des parents...
    Par exemple, si l'objet est inséré dans une frame ou un div.

    Autant pour moi.
    Darkyl, celui qui conduit quand il boit pas .(faudra penser passer le permis )

Discussions similaires

  1. Récupérer une variable dans un fichier par rapport à l'emplacement d'une autre
    Par FlorianBreizh dans le forum Shell et commandes GNU
    Réponses: 9
    Dernier message: 10/12/2012, 11h05
  2. Réponses: 2
    Dernier message: 19/11/2012, 19h44
  3. Réponses: 0
    Dernier message: 19/11/2012, 11h57
  4. Réponses: 5
    Dernier message: 06/10/2011, 12h56
  5. Réponses: 5
    Dernier message: 10/12/2007, 15h24

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