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 :

Position d'une ancre


Sujet :

JavaScript

  1. #1
    Membre du Club
    Inscrit en
    Mai 2005
    Messages
    81
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Mai 2005
    Messages : 81
    Points : 56
    Points
    56
    Par défaut Position d'une ancre
    Salut!
    J'aimerais faire une fonction qui permettrait un sroll progressif jusqu'a une ancre .
    Le problème ( ) c'est que je ne sais pas comment récupérer la position (dans l'espace) de mes ancres. Quelqu'un pourrait il me m'aider ou me mettre sur la voie SVP.
    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 643
    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 643
    Points : 66 669
    Points
    66 669
    Billets dans le blog
    1
    Par défaut
    FAQ offsetTop

  3. #3
    Membre du Club
    Inscrit en
    Mai 2005
    Messages
    81
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Mai 2005
    Messages : 81
    Points : 56
    Points
    56
    Par défaut
    Merci de ta réponse spaceFrog, j'avais pas bien cherché dans la FAQ...
    J'ai réussi a faire ce que je voulais!!!
    Pour ceux que ca interesse:
    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
     
    function getElementYpos(el)
    {
    	var y = 0;
    	while(el.offsetParent)
    	{
    		y += el.offsetTop
    		el = el.offsetParent;
    	}
    	return y;
    }
    function getElementXpos(el)
    {
    	var x = 0;
    	while(el.offsetParent)
    	{
    		x += el.offsetLeft
    		el = el.offsetParent;
    	}
    	return x;
    }
     
    function goodScroll(idAncre){
    	var ySize = document.documentElement.clientHeight;
    	var xSize = document.documentElement.clientWidth;
    	var xPos = document.documentElement.scrollLeft;
    	var yPos = document.documentElement.scrollTop;
        pos = document.getElementById(idAncre);
    	ancreLeft = getElementXpos(pos);
    	ancreTop = getElementYpos(pos);
    	ScrollAnchor(xPos,yPos,ancreLeft,ancreTop);
    	//alert("Position Ancre left: "+ancreLeft+ " Top: "+ancreTop);
    }
     
    function ScrollAnchor(beginX,beginY,x,y){
    	var Y = 0;
    	var X = 0;
    	if(y>x)
    	{
    		for(Z=beginY;Z<=y;Z++)
    		{
    			if(Y<=y)
    			{
    				scrollTo(X,Y);
    				Y = Y + 6;
    			}
    			if(X<=x)
    			{
    				scrollTo(X,Y);
    				X = X + 3;
    			}
    		}
    	}
    	else
    	{
    		for(Z=beginX;Z<=x;Z++)
    		{
    			if(Y<=y)
    			{
    				scrollTo(X,Y);
    				Y = Y + 6;
    			}
    			if(X<=x)
    			{
    				scrollTo(X,Y);
    				X = X + 3;
    			}
    		}
    	}
    }
    et ça s'utilise de la façon suivant:
    //block1 <== id de l'élément à atteindre
    <a href="javascript:goodScroll('block1')">Section 1</a>
    EDIT:
    Attention, cette fonction ne fonctionne sous MAC. Quand j'aurais résolu le problème (si je le résous) je ferais un EDIT pour mettre le code à jour.

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 20/03/2015, 17h31
  2. Récupérer la position Y courante d'une ancre
    Par Marmotton76 dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 14/06/2011, 09h32
  3. [HTML] Position horizontale d'une ancre
    Par nicoaix dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 21/05/2008, 16h36
  4. Position d'une balise dans un document externe
    Par haypo dans le forum XML/XSL et SOAP
    Réponses: 4
    Dernier message: 18/07/2003, 02h56
  5. [VB6] Position d'une MDIchild dans un MDI
    Par pepper dans le forum VB 6 et antérieur
    Réponses: 6
    Dernier message: 29/01/2003, 14h02

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