Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > JavaScript
JavaScript Forum programmation JavaScript. Lire : Cours JavaScript, FAQ JavaScript, Toutes les FAQ JavaScript et Sources JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 14/06/2011, 13h27   #1
Expert Confirmé
 
Avatar de sekaijin
 
Femme
Urbaniste
Inscription : juillet 2004
Messages : 1 421
Détails du profil
Informations personnelles :
Sexe : Femme
Âge : 48
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Urbaniste
Secteur : Santé

Informations forums :
Inscription : juillet 2004
Messages : 1 421
Points : 2 809
Points : 2 809
Par défaut [DOM]prepend et enrichissement du Dom

Suite à une discussion sur ce forum j'ai repensé à la problématique de façon plus générale.

la question était comment insérer un ligne en première position dans un tableau.

de façon plus globale avec DOM on peut se poser la question
"Comment insérer un Element comme premier fils ?"

la solution est relativement simpe puisque insertBefore permets d'insérer avant un Element et firstChild donne le premier.
insérer avant le premier réponds donc bien à la problématique.

on peut sen faire une petite fonction. mais en fait on peut aller plus loin:
enrichir le DOM une méthode prepend sur n'importe quel Element serait bienvenue

c'est l’approche que je vous propose.

Ajouter des méthodes au DOM c'est possible et c'est efficace.
Code :
1
2
3
4
5
6
7
  Element.constructor.prototype.prepend = function(el) {
    if (this.hasChildNodes()) {
      this.insertBefore(el, this.firstChild);
    } else {
      this.appendChild(el)
    }
  }
Nous ajoutons au prototype du constructeur d'Element DOM la méthode insertFirst
rien de plus que ce que nous aurions écrit pour un élément donnée.

l'avantage c'est qu'à partir de là tout objet DOM bénéficie de cette méthode.
un exemple :
Code html :
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
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
<script type="text/javascript" charset=iso-8859-1>
  Element.constructor.prototype.prepend = function(el) {
    if (this.hasChildNodes()) {
      this.insertBefore(el, this.firstChild);
    } else {
      this.appendChild(el)
    }
  }
</script>
  <meta http-equiv="content-type" content="text/html; charset=windows-1250">
  <meta name="generator" content="PSPad editor, www.pspad.com">
  <title>test</title>
<script type="text/javascript" charset=iso-8859-1>
  function test() {
    //ajout d'un HR comme premier fils du parent de l'élément d'id 1 (ici le body)
    doc = document.getElementById(1).parentNode;
    doc.prepend(document.createElement('hr'));
 
    // ajout d'un premier fil à l'élément d'id 1 (qui n'en a pas encore)
    h1 = document.getElementById(1);
    h1.prepend(document.createTextNode('Hello'));
  }
</script>
  </head>
  <body onload="test()">
    pour test
    <h1 id='1' />
  </body>
</html>

Cette approche consistant à ajouter des méthode au DOM peut être employée pour tout ce qui vous parait nécessaire. par exemple vous ajoutez souvent des paquets d'attribut à des éléments rien de plus simple
Code :
1
2
3
4
5
  Element.constructor.prototype.setAttributes(attributes) {
    for (key in attributes) {
      this.setAttribute(key, attributes[key]);
    }
  }
du coup
Code :
1
2
3
4
5
6
document.getElementById(1).setAttributes({
  align: "center",
  className: "truc",
  lang: "fr",
  dir: "ltr"
});
A+JYT
sekaijin est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 13h55   #2
Expert Confirmé Sénior
 
Avatar de RomainVALERI
 
Homme Romain VALERI
POOête
Inscription : avril 2008
Messages : 2 572
Détails du profil
Informations personnelles :
Nom : Homme Romain VALERI
Âge : 35
Localisation : France, Meurthe et Moselle (Lorraine)

Informations professionnelles :
Activité : POOête

Informations forums :
Inscription : avril 2008
Messages : 2 572
Points : 4 074
Points : 4 074
Le principe me plait ^^
Par contre si je ne m'abuse, les versions d'IE ne veulent pas de la surcharge des éléments DOM.... si ?
__________________

...pour les linguistes et les curieux >>> générateur de phrases aléatoires

__________________
RomainVALERI est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 14h01   #3
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 807
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : juin 2008
Messages : 13 807
Points : 35 797
Points : 35 797
Citation:
Envoyé par RomainVALERI
Par contre si je ne m'abuse, les versions d'IE ne veulent pas de la surcharge des éléments DOM.... si ?
Les interfaces Element sont accessibles depuis la version 8 il me semble
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, contactez-moi !
Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
Mon livre sur jQuery
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 14h01   #4
Rédacteur/Modérateur
 
Avatar de SpaceFrog
 
Homme
Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Inscription : mars 2002
Messages : 30 019
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Royaume-Uni

Informations professionnelles :
Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Secteur : Industrie

Informations forums :
Inscription : mars 2002
Messages : 30 019
Points : 45 114
Points : 45 114
y'a tout ça déja dans jquery non ?
__________________
Ma page 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


réalisations :www.planet-languages.com|www.saftair.com| www.ouestisol.fr | www.sebemex.fr | www.extramiante.fr | www.sistac-alizay.fr | www.acoustishop.fr | www.litt.fr | www.ouestventil.fr
SpaceFrog est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 14h35   #5
Expert Confirmé
 
Avatar de sekaijin
 
Femme
Urbaniste
Inscription : juillet 2004
Messages : 1 421
Détails du profil
Informations personnelles :
Sexe : Femme
Âge : 48
Localisation : France, Yvelines (Île de France)

Informations professionnelles :
Activité : Urbaniste
Secteur : Santé

Informations forums :
Inscription : juillet 2004
Messages : 1 421
Points : 2 809
Points : 2 809
non JQuer n'agit pas ainsi lorsque tu fait un tu obtient un objet jQuery (un simple objet javascript)
cet objet contient une référence à l'élément DOM correspondant
les méthodes sont des méthodes de l'objet jQuery.

A+JYT
sekaijin est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 14/06/2011, 14h38   #6
Rédacteur/Modérateur
 
Avatar de SpaceFrog
 
Homme
Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Inscription : mars 2002
Messages : 30 019
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : Royaume-Uni

Informations professionnelles :
Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Analyste Programmeur
Secteur : Industrie

Informations forums :
Inscription : mars 2002
Messages : 30 019
Points : 45 114
Points : 45 114
Oui mais non ^^
je veux dire au niveau du prepend

Mais surcharger le DOM ... je m'en méfierais, d'une part comme le dit Beef au niveau de la compatibilité, d'autre part je me suis déja fait avoir ensuite sur des boucles sur les propriétés des éléments en oubliant hasOwnPorperty
__________________
Ma page 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


réalisations :www.planet-languages.com|www.saftair.com| www.ouestisol.fr | www.sebemex.fr | www.extramiante.fr | www.sistac-alizay.fr | www.acoustishop.fr | www.litt.fr | www.ouestventil.fr
SpaceFrog est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/07/2011, 19h44   #7
Nouveau Membre du Club
 
Inscription : février 2006
Messages : 33
Détails du profil
Informations forums :
Inscription : février 2006
Messages : 33
Points : 29
Points : 29
Par défaut Hmm . . .

Il existe PrototypeJS qui fait cela à merveille, on lui reproche justement de modifier le DOM.

Je t'invite à lire la critique de Kangax qui a fait partie de l'équipe de PrototypeJS.

Je suis trés interresé par ton avis, si tu pouvais nous en faire part aprés ta lecture, je t'en remercie d'avance.
DontShootMe est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 23/07/2011, 21h05   #8
Expert Confirmé Sénior
 
Avatar de RomainVALERI
 
Homme Romain VALERI
POOête
Inscription : avril 2008
Messages : 2 572
Détails du profil
Informations personnelles :
Nom : Homme Romain VALERI
Âge : 35
Localisation : France, Meurthe et Moselle (Lorraine)

Informations professionnelles :
Activité : POOête

Informations forums :
Inscription : avril 2008
Messages : 2 572
Points : 4 074
Points : 4 074
Citation:
Envoyé par DontShootMe Voir le message
Il existe PrototypeJS qui fait cela à merveille, on lui reproche justement de modifier le DOM.

Je t'invite à lire la critique de Kangax qui a fait partie de l'équipe de PrototypeJS.

Je suis trés interresé par ton avis, si tu pouvais nous en faire part aprés ta lecture, je t'en remercie d'avance.
Excellent article ^^

(même si déjà relativement connu (enfin, ici en tout cas)... )
Citation:
"What’s wrong with extending the DOM" [... article ...]
April 5th, 2010
__________________

...pour les linguistes et les curieux >>> générateur de phrases aléatoires

__________________
RomainVALERI est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h13.


 
 
 
 
Partenaires

Hébergement Web