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] Avis aux amateurs RegExp


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    LEK
    LEK est déconnecté
    Membre éclairé
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    715
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2005
    Messages : 715
    Par défaut [DOM] Avis aux amateurs RegExp
    Bonjour,
    j'essaye en partant d'une chaine contenant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <span valID="a">contenu</span>
    <span valID="b">contenu 2</span>
    <span valID="c">contenu 3</span>
    <span valID="d">contenu 4</span>
    d'écrire une expression régulière (comme on pourrait faire avec xsl) qui me permette de remplacer l'ancien contenu de la chaine en :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <div valID="a" id="oSpan_1">contenu</div>
    <div valID="b" id="oSpan_2">contenu 2</div>
    <div valID="c" id="oSpan_3">contenu 3</div>
    <div valID="d" id="oSpan_4">contenu 4</div>
    Le problème vient de la valeur X de id="oSpan_X" : est-il possible de connaitre l'index du numéro d'occurence dans la chaine pour pouvoir l'incrémenter?
    Si ceci n'est pas réalisable : est-il au moins possible de créer un attribut alternatif d'une occurence sur deux de cette manière :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <div valID="a" altern="oSpan_1">contenu</div>
    <div valID="b" altern="oSpan_2">contenu 2</div>
    <div valID="c" altern="oSpan_1">contenu 3</div>
    <div valID="d" altern="oSpan_2">contenu 4</div>

  2. #2
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    bonjour,

    voici un exemple (j'ai considéré que la chaine à traiter était dans une seule variable et ne possèdait aucun caractère d'échappement comme le retour à la ligne) :
    Code javascript : 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
     
      var chaine = "";
      var tabChaine = new Array();
      var i, n, chaine2, exp;
     
      // la chaine est consituee d une ligne...
      chaine  = '<span valID="a">contenu</span>';
      chaine += '<span valID="b">contenu 2</span>';
      chaine += '<span valID="c">contenu 3</span>';
      chaine += '<span valID="d">contenu 4</span>';
     
     
      //on remplace les span par les div
      chaine = chaine.replace(/<span valID=/gi,"<div valID=");
      chaine = chaine.replace(/<\/span>/gi,"</div>");
     
      //on ajoute \n entre chaque div (plus simple ensuite pour le split)
      chaine = chaine.replace(/></gi,">\n<");
     
      //on separe chaque chaine au niveau du \n ajoute precedemment
      tabChaine = chaine.split(/\n/gi);
      n = tabChaine.length;
      //alert(tabChaine);
     
     
      //<div valID="a" sous forme de regexp (sans le > a la fin):
      //on considere que valID est constitue uniquement de lettres (intervalle [a-z])
      exp = /<div\s*valID=\"[a-z]*\"/gi;
     
      for (i=0; i<n; i++)
      {
         //extraction du debut de la chaine
         chaine2 = tabChaine[i].match(exp).toString();
     
         //insertion des id
         chaine2 = chaine2 + " id=\"oSpan_"+parseInt(i+1)+"\"";
     
         //on remplace la regexp par la nouvelle chaine
         tabChaine[i] = tabChaine[i].replace(exp, chaine2);
      }
     
      alert(tabChaine);

  3. #3
    Membre Expert
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juillet 2004
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 725
    Par défaut
    Les regex pour ajouter??? Drole d'utilisation... Le code de Auteur est bien

  4. #4
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    Citation Envoyé par cerede2000
    Les regex pour ajouter??? Drole d'utilisation... Le code de Auteur est bien
    Plus précisément, pour insérer une chaine au milieu d'une autre

    Il y a sans doute plus simple, mais merci pour le compliment cerede2000

  5. #5
    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 659
    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 659
    Billets dans le blog
    1
    Par défaut
    je hais les regExp ...
    Alors quand je peux faire sans ...
    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
     
     
    <script type='text/javascript'>
    function populate(){
    var SpanCollect=document.getElementsByTagName('span');
    for (i=0;i<SpanCollect.length;i++){
       SpanCollect[i].id="oSpan_"+Number(i+1);
       SpanCollect[i].onclick=function(){alert(this.id)}
       }
       }
    </script>
    </head>
     
    <body onload='populate()'>
     
    <span valID="a">contenu</span>
    <span valID="b">contenu 2</span>
    <span valID="c">contenu 3</span>
    <span valID="d">contenu 4</span>
     
     
    </body>
    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 !

  6. #6
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    certes.... mais il faut aussi transformer les span en div

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

Discussions similaires

  1. Réponses: 14
    Dernier message: 04/03/2013, 08h51
  2. QCM sur un attribut UML : avis aux amateurs
    Par frynt dans le forum Diagrammes de Classes
    Réponses: 1
    Dernier message: 06/01/2012, 09h23
  3. [RegExp] Avis aux Initiés, j'y connais pas grand chose
    Par Okena dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 04/05/2007, 15h31
  4. avis aux amateurs(trices) de la SDL !!
    Par iss942001 dans le forum C
    Réponses: 2
    Dernier message: 13/06/2005, 17h43
  5. avis aux experts-Quels sont les logiciels les plus adaptés??
    Par chouchouappc dans le forum Décisions SGBD
    Réponses: 46
    Dernier message: 20/07/2004, 21h26

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