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 :

Find and Replace


Sujet :

JavaScript

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Février 2010
    Messages
    573
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 573
    Points : 97
    Points
    97
    Par défaut Find and Replace
    Bonjour,

    Je voulais savoir si en JS, il était possible de cherche un mot dans un page html et de remplacer ce mot par un autre mot ou par exemple le mettre en gras ?

    Thais

  2. #2
    Rédacteur/Modérateur

    Avatar de yahiko
    Homme Profil pro
    Développeur
    Inscrit en
    Juillet 2013
    Messages
    1 424
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur

    Informations forums :
    Inscription : Juillet 2013
    Messages : 1 424
    Points : 8 710
    Points
    8 710
    Billets dans le blog
    43
    Par défaut
    A priori oui.
    En faisant une recherche sur document.body.innerHTML.

  3. #3
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    oui et non

    effectivement yahiko à raison innerHTML contient bien le code source de la page
    un appel à replace remplacera le mot
    mais en fait il va aussi changer toute la page.

    modifier le innerHTML d'un élément revient à supprimer son contenu et le remplacer par le DOM correspondants au code HTML fourni.

    si donc des valeurs ont changés (variable js) après le replace la page sera comme à l'origine (les modifs seront perdues)

    mais il est possible de chercher tous les textNodes et de remplacer le texte dans ceux-ci
    c'est long mais pas compliqué.

    il est grandement préférable de mettre un id sur l'élément modifiable et de ne sélectionner que selui-ci lors du remplacement

    A+JYT

  4. #4
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    Il est effectivement préférable de préciser un sous-conteneur contenant le texte à remplacer pour des raisons évidentes de performance et de prévention de problèmes. Par contre un ID n'est pas forcément le plus approprié, attention avec les mauvais réflexes.

    Un exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
       var node;
        var walker = document.createTreeWalker(
            elementSousConteneur, 
            NodeFilter.SHOW_TEXT, 
            null, 
            false
        );
     
        while(node = walker.nextNode()) {
            node.textContent = node.textContent.replace("mot-a-remplacer", "remplacement");
        }

  5. #5
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    je pense tout de même que si on n'a à modifier qu'un seul élément
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById("myId").innerText.replace("mot-a-remplacer", "remplacement");
    est plus efficace.

    je maintiens que l'ID est une bonne pratique. même si très souvent je dis qu'on peut efficacement s'en passer.

    A+JYT

  6. #6
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Points : 9 944
    Points
    9 944
    Par défaut
    L'ID n'est pas une bonne pratique, pas plus que ne l'est la classe, le tagName ou toute autre forme de sélection. La bonne pratique, c'est de choisir le plus approprié selon la situation. Et au vu du nombre de gens qui ne connaissent rien d'autre que document.getElementById, il me paraît important de mentionner les autres options.

    Et pour info, innerText n'est pas standard. C'est textContent qu'il faut utiliser.

Discussions similaires

  1. Find and Replace
    Par Newenda dans le forum MATLAB
    Réponses: 2
    Dernier message: 02/06/2009, 15h38
  2. Faire un Find and Replace dans un DataGridView
    Par Contrec dans le forum C#
    Réponses: 5
    Dernier message: 29/08/2007, 09h40
  3. Find and replace sur plusieur fichiers
    Par dazhoid dans le forum MATLAB
    Réponses: 1
    Dernier message: 30/08/2006, 16h18
  4. find and replace dans word
    Par Thargor dans le forum API standards et tierces
    Réponses: 8
    Dernier message: 21/06/2006, 15h01

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