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 :

[DOM] REGEX pour supprimer des spans


Sujet :

JavaScript

  1. #1
    Membre actif
    Inscrit en
    Octobre 2005
    Messages
    908
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 908
    Points : 271
    Points
    271
    Par défaut [DOM] REGEX pour supprimer des spans
    Bonjour,

    j'essaye d'utiliser une expression régulière pour supprimer une balise HTML SPAN.
    Pour le moment, j'arrive à supprimer la balise d'ouverture mais pas celle de fermeture...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    var maReg = new RegExp('<span class="truc">', "gi");
    var texte = document.getElementById('zone').innerHTML;
    document.getElementById('zone').innerHTML = texte.replace(maReg, '');
    avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <div id="zone">
    <p>blabla</p><span class="truc">abcdef<span class="zen">encore du blabla</span>ghijkl</span>
    </div>
    Quelle regex me faudrait-il pour enlever le span avant 'abcdef' et après 'ghijkl' ?
    Merci d'avance...

  2. #2
    Rédacteur
    Avatar de bigboomshakala
    Homme Profil pro
    Consultant Web .NET
    Inscrit en
    Avril 2004
    Messages
    2 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Consultant Web .NET
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2004
    Messages : 2 077
    Points : 2 757
    Points
    2 757
    Par défaut
    utilise le DOM ce sera plus simple...
    tu parcoures l'arborescence de ton document HTML. quand tu rencontres un span, tu sauvegarde son contenu dans une variable, tu supprimes le noeud SPAN de l'élément supérieur auquel il est attaché et tu ajoutes son contenu à la place (procédé qui doit être récursif pour supprimer les éventuels span imbriqués)

  3. #3
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    soit dans ton cas précis:


    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
     
    <div id="zone">
    <p>blabla</p><span class="truc">abcdef<span class="zen">encore du blabla</span>ghijkl</span>
    </div>
     
     
    <script type="text/javascript"> 
     
    var z=document.getElementById("zone");
    var sp=z.getElementsByTagName("span")[0];
     
    while(sp.firstChild){
    	z.appendChild(sp.firstChild);
    }
     
     
    z.removeChild(sp);
     
     
    </script>

  4. #4
    Membre actif
    Inscrit en
    Octobre 2005
    Messages
    908
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 908
    Points : 271
    Points
    271
    Par défaut
    Bonjour et merci pour vos réponses...

    effectivement l'idée d'utiliser la DOM peut être une bonne idée.
    Cependant, j'ai 2 problèmes :
    1/ comment filtrer les span ayant class="truc" ?
    2/ l'ajout / suppression des nœuds dans la DOM chamboule tout... ils ne sont plus à leur place... il suffit qu'un DIV se trouve entre le nœud cible et les spans pour mettre le bazar


Discussions similaires

  1. [RegEx] Expression régulière pour supprimer des doublons
    Par cbroissa dans le forum Langage
    Réponses: 5
    Dernier message: 20/05/2017, 01h59
  2. Réponses: 2
    Dernier message: 29/08/2006, 13h59
  3. Réponses: 45
    Dernier message: 04/05/2006, 01h10
  4. Utiliser awk pour supprimer des retours charrios
    Par tomsoyer dans le forum Linux
    Réponses: 3
    Dernier message: 03/01/2005, 18h27
  5. Shell pour supprimer des lignes d'un fichier
    Par nelsa dans le forum Autres langages
    Réponses: 2
    Dernier message: 20/09/2004, 12h26

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