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 :

C'est possible : href.onmouseover.replace ?


Sujet :

JavaScript

  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut C'est possible : href.onmouseover.replace ?
    Bonjour,

    j'ai un code pour remplacer certains éléments des liens d'une page
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    var oLien = document.links;
    (...)
    oLien[i].href = oLien[i].href.replace('Atchoum', 'Snif');
    Ça marche bien.
    Mais si j'essaie de modifier le contenu du onmouseover de ce lien cela ne va pas...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    oLien[i].href.onmouseover = oLien[i].href.onmouseover.replace('TrucBidule', 'TrucMuche');
    Quel(s) problème(s) ?


    Merci
    Paul

  2. #2
    Membre Expert

    Homme Profil pro
    Ingénieur Hospitalier
    Inscrit en
    Juillet 2004
    Messages
    993
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur Hospitalier
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 993
    Billets dans le blog
    1
    Par défaut
    Salut Mister Paul
    Je pense que tu n'a pas intégré, que tu accède a un attribut d'un élément object html.
    En gros tu cible une liste Object html links (collection d'object html) correspondant à tous les liens (<a >) contenue dans ta page :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    var oLien = document.links;
    Dans ta collection d'object html "oLien" est devenu un tableaux (collection html) qui te permettra de parcourir tes éléments et de faire ce que tu souhaite.

    En regardant un élément (<a >) on a, à l'intérieur des propriétés ou attribut, qui te permettra de paramétrer différentes propriété propre à l'élément par exemple des propriétés sur l'élément :
    Propriété physiques : attribut : style, width, height...
    Propriété événementielles : onclick,onchange,... et qui sont des function facilement manipulable en javascript.
    Donc tu veux par le biais d'un onmouseover remplacer le text de ton attribut href par un autre.
    Ton code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    oLien[i].href.onmouseover = oLien[i].href.onmouseover.replace('TrucBidule', 'TrucMuche');
    correction
    pour la variable textque j'ai créé tu doit pour la changer la mettre en string, dans le 1er paramètre de replace j'ai mit l'url que contient réellement l'élément a href courant déclencher par l'événement onmouseover...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    var oLien = document.links;
    for(i in oLien){
      oLien[i].onmouseover = function(){
      var text = toString(this.href).replace(toString(this.href),"trucmuche");
        this.removeAttribute('href'); //on supprime attribut href
         this.setAttribute('href', text); //on recréer un nouveau attribut href on change la valeur du href par la nouvelle
      };
    }
    Bonne soirée, un petit résolu et une note fait toujours plaisir, bonne soirée .

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut
    Argh... je me suis mal exprimé désolé...


    Je ne cherche pas à changer le contenu d'un href lors d'un mouseover,
    je cherche à remplacer toutes les occurrences de "TrucBidule", dans le contenu de l'attribut onmouseover des liens d'une page, pour les remplacer par "Trucmuche"...

  4. #4
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Bonsoir,
    ce n'est pas gagné!
    L'attribut onmouseover étant une fonction anonyme, les différents navigateurs ne l'interpréterons pas de la même façon.

    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
    <!DOCTYPE html>
    <html lang="fr">
    <head>
    <meta charset="UTF-8">
    </head>
    <body>
    <a id ="a_test" href="#" onmouseover="alert(this.href);">Lien test</a>
    <script>
      var oLien = document.links[0];
      var sCde = oLien.getAttribute( 'onmouseover')
      sCde = sCde.toString().replace('href', 'id');
      oLien.setAttribute( 'onmouseover', sCde)
    </script>
    </body>
    </html>
    ne fonctionne pas avec IE, au moins jusqu'à la v8.

    Je ne pense pas que cela soit la bonne approche

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut
    Remarque si ça n'handicape que les anciens IE c'est quand même pas mal...

  6. #6
    Modérateur

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

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 198
    Par défaut
    Je te laisses faire les tests complémentaires, mais je persiste dans le fait que cela ne me paraît pas une bonne idée, mais ne connaissant pas les tenants et aboutissants ....

  7. #7
    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 : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    J'imagine que si tu nous décrivais correctement ce que tu veux faire, on pourrait t'indiquer une solution beaucoup plus propre...
    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

  8. #8
    Membre éclairé
    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 : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Billets dans le blog
    1
    Par défaut
    Bonjour

    je cherche à remplacer toutes les occurrences de "TrucBidule", dans le contenu de l'attribut onmouseover des liens d'une page, pour les remplacer par "Trucmuche"...
    Mais, bon, j'ai pas tout compris non plus...

  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 658
    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 658
    Billets dans le blog
    1
    Par défaut
    quand ?
    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
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut
    En fait, je souhaite modifier le contenu de certains liens lors de l'ouverture de la page : le contenu du href et du onmouseover
    que
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="http://www.allezAtchoum.com" onmouseover="bla bla bla TrucBidule bla bla bla...">mon lien</a>
    devienne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="http://www.allezSnif.com" onmouseover="bla bla bla TrucMuche bla bla bla...">mon lien</a>
    C'est OK pour le contenu du href avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    oLien[i].href = oLien[i].href.replace('Atchoum', 'Snif');
    Je cherchais pour le onmouseover...

  11. #11
    Membre éclairé
    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 : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Billets dans le blog
    1
    Par défaut
    On est bien d'accord que trucmuch ou trucmachin représente une fonction? et non un string...

  12. #12
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut
    Citation Envoyé par Darkyl Voir le message
    On est bien d'accord que trucmuch ou trucmachin représente une fonction? et non un string...
    nan, nan ce sont des strings

  13. #13
    Membre éclairé
    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 : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Billets dans le blog
    1
    Par défaut
    un string? heu, t'as un exemple?

    parce que onmouseover est un évènement (une fonction quoi) donc cela vaut obligatoirement une fonction (qui peut-être un string avec un eval)
    A moins que je ne me gourre complètement.

    Dans cette exemple:
    onmouseover="alert(this.href);"
    alert(this.href); est bien une fonction.

  14. #14
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut
    Oui
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    onmouseover="return overlib('je suis le commentaire d'origine')"
    qui devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    onmouseover="return overlib('je suis le commentaire modifié')"
    Dans ce cas on rechercherait "d'origine" pour le remplacer par "modifié"

  15. #15
    Membre éclairé
    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 : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Billets dans le blog
    1
    Par défaut
    Je comprend pas:

    onmouseover=" je suis le commentaire d'origine"
    ne veut rien dire...
    Je crois que tu confond avec ALT ou TITLE... non?

    onmouseover ne prend pas un string pour l'afficher, à moins que tu n'ai fait une fonction et que cela devienne:
    onmouseover="afficher('mon commentaire');";

  16. #16
    Membre éclairé
    Profil pro
    Inscrit en
    Février 2007
    Messages
    749
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 749
    Par défaut
    Oui tu as raison.
    Désolé j'éditais mon post précédent pendant que tu écrivais ta réponse…
    Regarde-le

  17. #17
    Membre éclairé
    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 : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Billets dans le blog
    1
    Par défaut
    ok, là on est d'accord, escuze si je demande des précisions mais c'était pour être sûr.

  18. #18
    Membre éclairé
    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 : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Billets dans le blog
    1
    Par défaut
    Le code de NoSmoking ne marche pas?
    Tu t'en sors pas avec?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    <script>
      var oLien = document.links[0];
      var sCde = oLien.getAttribute( 'onmouseover')
      sCde = sCde.toString().replace('truc d\'origine', 'truc modifié');
      oLien.setAttribute( 'onmouseover', sCde)
    </script>

  19. #19
    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 : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    On se demande vraiment à quoi peuvent bien servir les variables...
    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

  20. #20
    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 658
    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 658
    Billets dans le blog
    1
    Par défaut
    NoSmo a juste oublié la boucle sur Links ..
    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 !

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. [CR 10][Cross-tab] C'est possible d'avoir un rectangle ?
    Par Giovanny Temgoua dans le forum SAP Crystal Reports
    Réponses: 6
    Dernier message: 29/03/2005, 17h44
  2. Automatiser création Flash, c'est possible ? Java ou C++ ?
    Par touff5 dans le forum Langages de programmation
    Réponses: 3
    Dernier message: 16/01/2005, 11h01
  3. passer un champ en paramètre, c'est possible ??
    Par marie253 dans le forum Bases de données
    Réponses: 6
    Dernier message: 09/07/2004, 09h22
  4. Réponses: 1
    Dernier message: 18/06/2004, 01h12
  5. Réponses: 2
    Dernier message: 16/07/2003, 14h40

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