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

Bibliothèques & Frameworks Discussion :

[1.6] Attribution du style à un nouvel élément [Prototype]


Sujet :

Bibliothèques & Frameworks

  1. #1
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut [1.6] Attribution du style à un nouvel élément
    Bonjour,

    je souhaite attribuer un style a un élément nouvellement créé, je fais donc :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    b = new Element('div', {
    	id: 'b1',
    	style: "position:'absolute'; left:100px; top:100px; width:100px; height:100px; background-color: blue"
    });
    Seulement, cette méthode (au niveau du style devient vite illisible, d'autant plus quand des variables viennent s'en mêler...

    J'aimerai pouvoir écrire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    b = new Element('div', {
    	id: 'b1',
    	style: {position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
    });
    document.body.appendChild(b);
    Seulement cette écriture n'a pas l'air possible, (aucun affichage de div) avec la seconde méthode.

    Je me suis planté quelque part?
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Ton objet style n'est pas fermé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    b = new Element('div', {
    	id: 'b1',
    	style: {position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
            }
    });
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, 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
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  3. #3
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Simple erreur de recopie, le problème n'est pas là...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    b = new Element('div', {
    	id: 'b1',
    // 	style: "position:'absolute'; left:100px; top:100px; width:100px; height:100px; background-color: blue"
    	style : {
    		position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
    	}
    });
    Ne fonctionne pas...

    Dans le code source généré (vu par Google Chrome) j'ai :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <div id="b1" style="[object Object]">
    Autrement dit, le code contenu dans le style recopié en tant qu'objet tel quel, tandis qu'avec la méthode commenté, le style est bien à jour
    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  4. #4
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Et en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    b = new Element('div', {
    	id: 'b1',
    // 	style: "position:'absolute'; left:100px; top:100px; width:100px; height:100px; background-color: blue"
    	'style' : {
    		position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
    	}
    });
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, 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
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Membre expérimenté
    Avatar de gwyohm
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2007
    Messages
    925
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Octobre 2007
    Messages : 925
    Points : 1 333
    Points
    1 333
    Par défaut
    Salut

    Je crois en effet qu'on ne peut pas le faire... Solution : faire un new Element sans le style puis un setStyle :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    var b = new Element('div', {id: 'b1'}).setStyle({
    		position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
    	});
    on ne dit pas "ça ne marche pas" on dit "je suis incapable de faire fonctionner correctement les outils mis à ma disposition"
    Pas de question technique par MP

  6. #6
    Rédacteur
    Avatar de Arnaud F.
    Homme Profil pro
    Développeur COBOL
    Inscrit en
    Août 2005
    Messages
    5 183
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France

    Informations professionnelles :
    Activité : Développeur COBOL
    Secteur : Finance

    Informations forums :
    Inscription : Août 2005
    Messages : 5 183
    Points : 8 873
    Points
    8 873
    Par défaut
    Citation Envoyé par Bovino Voir le message
    Et en faisant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    b = new Element('div', {
    	id: 'b1',
    // 	style: "position:'absolute'; left:100px; top:100px; width:100px; height:100px; background-color: blue"
    	'style' : {
    		position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
    	}
    });
    Perdu !

    Citation Envoyé par gwyohm Voir le message
    Salut

    Je crois en effet qu'on ne peut pas le faire... Solution : faire un new Element sans le style puis un setStyle :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    var b = new Element('div', {id: 'b1'}).setStyle({
    		position:'absolute',
    		left:'100px',
    		top:'100px',
    		width:'100px',
    		height:'100px',
    		backgroundColor: 'blue'
    	});
    C'est la solution que j'avais adopté sur le coup, et que je vais continuer à adopter vu que ça ne semble pas faisable depuis le constructeur ...


    C'est par l'adresse que vaut le bûcheron, bien plus que par la force. Homère

    Installation de Code::Blocks sous Debian à partir de Nightly Builds

  7. #7
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Effectivement, je viens de regarder un peu dans le code de la lib et la création d'éléments se fait en listant les propriétés passées à l'objet et en leur attribuant la valeur correspondante, il n'est donc pas possible de passer un objet comme valeur d'un attribut.
    C'est d'ailleurs dommage car ce ne serait pas trop compliqué à implémenter...
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, 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
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

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

Discussions similaires

  1. Appliquer un style à tous les éléments d'une table
    Par licorne dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 02/01/2007, 14h31
  2. Réponses: 5
    Dernier message: 12/08/2006, 20h35
  3. transposer en css les attributs de style d'un tableau
    Par psychoBob dans le forum Mise en page CSS
    Réponses: 8
    Dernier message: 15/06/2006, 08h34
  4. copier les attributs d un nouvel élément
    Par luta dans le forum XSL/XSLT/XPATH
    Réponses: 4
    Dernier message: 23/09/2004, 10h05
  5. Réponses: 5
    Dernier message: 24/04/2003, 11h47

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