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

AJAX Discussion :

[AJAX] Ancre HREF="#" comportement différent


Sujet :

AJAX

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de llaffont
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juin 2007
    Messages
    702
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Juin 2007
    Messages : 702
    Par défaut [AJAX] Ancre HREF="#" comportement différent
    Salut,

    J'ai un comportement bizarre sur ma page.

    J'ai plusieurs ancres HTML qui me servent d'interrupteur.
    La majorité de ces ancres me permettent de réduire le contenu d'un DIV définie et sont formulés comme suit :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    <div id="Reduc" class="alignLeft">
    	<a href="#" class="Reduire" >Réduire</a>	
    <div id="cibleAreduire"> BlaBlaBlaBlaBlaBlaBlaBlaBlaBlaBlaBla</div>
    </div>
    Ici tout fonctionne nickel.

    Sur la même page j'ai une ancre qui me permet de valider une ligne de formulaire.

    Voici en gros ce 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
     
    <div id="Reduc" class="alignLeft">
    	<a href="#" class="Reduire" >Réduire</a>	
    	<div id="cibleAreduire"> 
    	<table>
    		<tbody>
    			<tr> 
    				<td>Blabla</td>
    				<td>Blabla</td>
    				<td><a href="#" class="Valider" >Valider</a></td>
    			</tr>
    		</tbody>
    	</table>
    	</div>
    </div>
    Cette ancre là fonctionne pour son rôle d'interrupteur. Mais elle joue les funambules car lorsque je clique dessus elle lance le script JAVA et me remets l'ascenseur en haut de la page.

    La faute certainement à href="#".

    Ma question est : Pourquoi href="#" est interprété ici pour "valider" alors que pour réduire "Réduire" cela n'a aucune incidence sur l'ascenseur ?

  2. #2
    Membre éprouvé
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2009
    Messages
    180
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2009
    Messages : 180
    Par défaut
    Peut-être que pour ton premier lien , il n'y a pas de scroll. Tu sais tu peux utiliser a la place de # javascript:void(0) au moins la page ne se rafraichit pas.

  3. #3
    Expert éminent

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Par défaut
    Bonjour,
    Citation Envoyé par llaffont Voir le message
    Ma question est : Pourquoi href="#" est interprété ici pour "valider" alors que pour réduire "Réduire" cela n'a aucune incidence sur l'ascenseur ?
    La réponse se trouve dans les fonctions que tu utilises lors du clic sur ces liens, et la manière dont tu les affectes aux objets.

    En gros la méthode à utiliser (il y a bien sûr des variantes)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="#" onclick="traitement(); return false;">blabla</a>
    le return false empêche l'appel au href (même logique que le onsubmit d'un <form>).

    Si la fonction fait déjà un return false, un return traitement() suffit ...

    A+

  4. #4
    Membre éclairé Avatar de llaffont
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juin 2007
    Messages
    702
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Juin 2007
    Messages : 702
    Par défaut
    Ok ! je comprends.

    Mais jusqu'à présent j'utilisais le "gestionnaire d'évènement" de JQUERY $(function(){});

    Mon click il est interprété :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    $(".Valider").click(function(){
    	ActionCreateUser(this);	
    });
    Et la fonction ActionCreateUser() retourne de la mis à jour d'aspect.

    Le fait d'utiliser "onclick="traitement(); return false;"" ne me dérange pas mais pour une lecture plus propre de mon code vaut-il mieux que je mettes tous mes ancres avec onclick="traitement(); return false;" ou que je laisse à $(function(){}); traiter les évènements ?

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

Discussions similaires

  1. [AJAX] Comportement différent entre IE et FF2
    Par pacopau dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 14/02/2007, 19h18
  2. Comportement différent entre un bouton et une image
    Par MicheMTP13 dans le forum Général JavaScript
    Réponses: 11
    Dernier message: 07/11/2005, 08h47
  3. Comportement différent des listes [] et des tuples () ??
    Par JujuKéblo dans le forum Général Python
    Réponses: 2
    Dernier message: 12/10/2005, 09h08
  4. [C#] bouton avec 2 comportements différents ?
    Par st0j dans le forum ASP.NET
    Réponses: 8
    Dernier message: 31/05/2005, 09h50
  5. Réponses: 3
    Dernier message: 16/03/2005, 11h31

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