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 :

nodecleaner: le retour


Sujet :

JavaScript

  1. #1
    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 nodecleaner: le retour
    je tente une amélioration du vieux code mais je peine toujours: selon vous, c'est plus économique ou pas? ça a l'air de marcher en tout cas;

    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
    var q, bal, p;
     
    function clean(d){
    	bal=d.getElementsByTagName('*');
    	for(j=0;j<bal.length;j++){
    		if(!q){
    			q=true
    		}
    		else{
    			q=false;
    			continue
    		}
     
    		p=bal[j].parentNode.childNodes;
    		for(i=0;i<p.length;i++){alert("ok")
    			if(p[i].data && !p[i].data.replace(/\s/g,'')){
    				p[i].parentNode.removeChild(p[i])
    			};
    		q=false;
     
    		}
    	}
    }

  2. #2
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    Je n'ai pas suivis la première version mais un d.innerHTML = null ( oui c crad je sais ) ne fonctionnerait-il pas ? les noeuds existent-ils toujours en mémoire ??

  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
    ben nan, j'ai testé aussi et ça ne détruit pas le noeud;

    mais je viens de voir une connerie dans le code, il faut que je retravaille;

    [ah non, ça marche... une alert oubliée ]


    disons:

    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
    var q, bal, p;
     
    function clean(d){
    	bal=d.getElementsByTagName('*');
    	for(j=0;j<bal.length;j++){
    		if(!q){
    			q=true
    		}
    		else{
    			q=false;
    			j++;
    		}
     
    		p=bal[j].parentNode.childNodes;
    		for(i=0;i<p.length;i++){
    			if(p[i].data && !p[i].data.replace(/\s/g,'')){
    				p[i].parentNode.removeChild(p[i])
    			};
    		}
    	}
    }

  4. #4
    Membre éprouvé

    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    1 448
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 448
    Points : 1 234
    Points
    1 234
    Par défaut
    p=bal[j].parentNode.childNodes;

    =>

    p=bal[j].childNodes;

    Mieux ?

    C'est dégeux en tout cas ^^'
    Et je ferais un test sur le NodeType à la place de .data.

  5. #5
    Expert confirmé
    Avatar de le_chomeur
    Profil pro
    Développeur informatique
    Inscrit en
    Février 2006
    Messages
    3 653
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 3 653
    Points : 4 835
    Points
    4 835
    Par défaut
    question bète , mais pkoi ne pas faire une fonction avec un appel récursif , avec comme paramètre d'entré le noeud, puis sur chaque noeud a supprimer , on vérifit s'il a des enfants, si oui on rappel la fonction ...

  6. #6
    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
    Sergejack: on parle bien des noeuds frères, non des enfants

    le_chomeur: l'une des premières moutures explorait ce principe; après, le but était d'obtenir le moins de boucles / passage par boucle possible, et du coup, la récursivité était moyenne...

  7. #7
    Candidat au Club
    Inscrit en
    Février 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 2
    Points : 2
    Points
    2
    Par défaut
    Bonjour,

    C'est un vieux sujet mais qui est toujours d'actualité.
    J'ai développé un nodeCleaner récursif.
    Il est plutôt rapide. Qu'en pensez-vous ?

    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
    /*****************************************************************
    * Fonction récursive de suppression des noeuds texte dans un DOM *
    *         Synthaxe : deleteEmptyNodeText(noeudATraiter);         *
    *****************************************************************/
     
    function deleteEmptyNodeText(pere, fils) {
    	if(typeof(fils) == 'undefined') { // Si le 2ème argument (fils) n'est pas renseigné -> 1ère boucle
    		fils = pere; // Le fils devient le père
    		pere = fils.parentNode; // Et le père devient le père du fils
    		deleteEmptyNodeText(pere, fils); // On lance la fonction avec les 2 bons arguments
    	} else {
    		if(fils.hasChildNodes()) { // Si le fils a des enfants
    			deleteEmptyNodeText(fils, fils.firstChild); // On le traite en tant que père avec son 1er enfants
    		}
    		if(fils.nextSibling) { // Si le fils a un frère
    			deleteEmptyNodeText(pere, fils.nextSibling); // On le traite en gardant le même père et son enfant suivant
    		}
    		if(fils.nodeType == 3 && (fils.nodeValue.replace(/^\s+|\s+$/g, '').length == 0 || fils.nodeValue.charCodeAt(1) == 32)) { // Si il s'agit d'un noeud texte vide
    			pere.removeChild(fils); // On le supprime
    		}
    	}
    }

Discussions similaires

  1. Réponses: 8
    Dernier message: 12/02/2013, 01h08
  2. Retour au mode texte par défaut
    Par coca dans le forum x86 16-bits
    Réponses: 6
    Dernier message: 12/12/2002, 17h22
  3. [XP] Retour d'experience
    Par virgile04 dans le forum Méthodes Agiles
    Réponses: 10
    Dernier message: 22/10/2002, 08h25
  4. Retour chariot dans un TMemo ?
    Par Vincent PETIT dans le forum C++Builder
    Réponses: 7
    Dernier message: 27/08/2002, 18h55
  5. URGENT: retour de string
    Par Pinggui dans le forum CORBA
    Réponses: 4
    Dernier message: 15/07/2002, 09h47

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