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 :

Problème highlight word


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Inscrit en
    Juin 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 4
    Par défaut Problème highlight word
    Bonjour à tous,

    je cherche à réaliser un moteur de recherche interne pour une page html de type google bar (highlight)...
    pour cela j'utilise le innerHTML

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    page_content = document.body.innerHTML;
    puis je modifis le contenu avec une RegExp et un replace
    et enfin je réaffectes le contenu modifié à mon innerHTML

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.body.innerHTML=new_page_content;
    jusqu'ici tout va bien, en revanche le problème se complique lorsque je recherche un mot du même nom qu'une balise HTML (ex: table, tr, td...) : en effet la partie html recherche s'affiche dans la page (<td.. ).

    Faut-il créer une expression régulière pour inhiber les balises (pour ne pas rechercher ma chaine dans les balises) ?
    ou
    Faut-il utiliser le textContent ? (mais sans pour autant perdre les styles)


    Merci d'avance
    Olive


    Source complète:

    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
    71
    72
    73
     
    // function color word
    function KeyWordGetColor(idx)
    {
      var color = '#CCCCCC';
      switch (idx)
      {
        case 0:
          color='yellow'; break;
        case 1:
          color='#99FF99'; break;
        case 2:
          color='#FFCCFF'; break;
        case 3:
          color='#CC99FF'; break;
        case 4:
          color='#99CCFF'; break;
        case 5:
          color='#FFCC99'; break;
        case 6:
          color='#CCCCFF'; break;
        case 7:
          color='#66CCFF'; break;
        default:
          break;
      }
      return color;
    }
     
    // function trim string
    function allTrim(sString)
    {
      while (sString.substring(0,1) == ' ')
      {
        sString = sString.substring(1, sString.length);
      }
      while (sString.substring(sString.length-1, sString.length) == ' ')
      {
        sString = sString.substring(0,sString.length-1);
      }
      return sString;
    }
     
     
    // function search string
    nbterm=0;
    function search()
    {
      // recuperation de la chaine recherche
      searchTerms=document.getElementById("motcle");
      //creation du inner
      b = document.body.innerHTML;
      //excution de la fonction trim
      searchTerms=allTrim(searchTerms.value)
      searchArray = searchTerms.split(" ");
      for (var i = 0; i < searchArray.length; i++)
      {
        newcontent = dohighlight(searchArray[i], nbterm, b);
        nbterm++;
      }
      document.body.innerHTML=newcontent;
      return true;
    }
     
    // function highlight
    function dohighlight(term, nbterm)
    {
      s='('+term+')';
      x=new RegExp(s,'gi');
      alert(x);
      b=b.replace(x,'<span style=\'background-color:'+KeyWordGetColor(nbterm)+'\';>$1</span>');
      return b;
    }

  2. #2
    Membre confirmé Avatar de NeoMan
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 171
    Par défaut
    Pourquoi ne pas faire une recherche sur " table ", " td ", " tr " au lieu de "table", "td", "tr" ? Si c'est des mots entiers que tu veux souligner, il y a forcément au moins un espace avant et après (ah il peut aussi y avoir des '-' ou des '/' par exemple mais ça se gère très bien en expression régulière). Ainsi il ne prendra pas les "<table " du code source...

    non ?

    @++

    NeoMan

  3. #3
    Futur Membre du Club
    Inscrit en
    Juin 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 4
    Par défaut
    En fait il me faut aussi pouvoir rechercher autre chose que des mots entiers !!!

    merci
    Olivier

  4. #4
    Membre confirmé Avatar de NeoMan
    Profil pro
    Inscrit en
    Avril 2002
    Messages
    171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2002
    Messages : 171
    Par défaut
    Comme ?

  5. #5
    Futur Membre du Club
    Inscrit en
    Juin 2004
    Messages
    4
    Détails du profil
    Informations forums :
    Inscription : Juin 2004
    Messages : 4
    Par défaut
    par example, il faudrait pouvoir trouver "win" dans la chaine "winzip" !!!

    Olive

  6. #6
    Membre à l'essai
    Inscrit en
    Mars 2003
    Messages
    5
    Détails du profil
    Informations forums :
    Inscription : Mars 2003
    Messages : 5
    Par défaut
    Voila un exemple pas mal :

    Solution ICI


    gui

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

Discussions similaires

  1. Problème Quitter Word
    Par aaliyan dans le forum VBA Word
    Réponses: 2
    Dernier message: 27/04/2007, 11h26
  2. Problème Publipostage Word
    Par aures64 dans le forum VB 6 et antérieur
    Réponses: 3
    Dernier message: 30/01/2007, 20h31
  3. [Système] probléme PHP Word
    Par hamzito dans le forum Langage
    Réponses: 7
    Dernier message: 31/07/2006, 13h32
  4. [COM] Problème lié word
    Par mosca_coroneja dans le forum Bibliothèques et frameworks
    Réponses: 10
    Dernier message: 23/03/2006, 11h35
  5. Probléme VBA Word et SQL server
    Par andrau dans le forum VBA Word
    Réponses: 2
    Dernier message: 12/10/2005, 11h52

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