Rechercher : dans
Par :

Problème de guillemets dans le Javascript

Dernière réponse le 30 mai 2008 à 21:14:57 Dédé86, le 28 mai 2008 à 11:58:22 
 Signaler ce message aux modérateurs

Bonjour,

J'ai un problème dans le code suivant au niveau des guillemets. Je ne sais jamais comment les utiliser correctement et ça m'agace. Pouvez-vous m'aider svp ? Le code affiche correctement le nom des couleurs de mon tableau mais pas le style correspondant à la couleur. (Bien sûr, avant il y a une boucle mais que je n'ai pas écrite).



document.write("<option style='background-color:'+mesCouleurs[i];'>"+mesCouleurs[i]+"</option>");

Merci d'avance de votre aide.

Meilleures réponses pour « Problème de guillemets dans le Javascript » dans :

1

JR des cavernes, le 28 mai 2008 à 12:03:16

J'aurais mis quelque chose du genre :
document.write("<option style='background-color:" + mesCouleurs[i] ";'>" + mesCouleurs[i] + "</option>");

Répondre à JR des cavernes

2

Dédé86, le 28 mai 2008 à 12:09:42

Merci mais ça ne fonctionne pas :(

Répondre à Dédé86

3

JR des cavernes, le 28 mai 2008 à 12:17:16

J'ai oublié un + :

document.write("<option style='background-color:" + mesCouleurs[i] + ";'>" + mesCouleurs[i] + "</option>");

Je sais pas si le pb est là...

Répondre à JR des cavernes

4

Dédé86, le 28 mai 2008 à 12:19:49

Oui ça fonctionne merci beaucoup mais peux tu m'expliquer l'imbrication des guillemets ? a quel moment je dois mettre des guillemets simples et des guillemets doubles ?? merci d'avance.

Répondre à Dédé86

5

JR des cavernes, le 28 mai 2008 à 12:31:07

Alors :

En fait, les guillemets simples doivent être dans le guillemets doubles. Ils servent à séparer les variables (mesCouleurs[i]) du texte (<option style='background-color:).

Par exemple si tu as du mal tu peux faire comme ça :

tu écris ton texte avec aucun guillemets double :

<option style='background-color:mesCouleurs[i] ;'>mesCouleurs[i]</option>

puis tu encadre toutes tes variables avec : "+ variable +" et tu mets le tout entre guillemets :

"<option style='background-color:" + mesCouleurs[i] + ";'>" + mesCouleurs[i] + "</option>"

Normalement ça marche !

Répondre à JR des cavernes

6

Dédé86, le 28 mai 2008 à 14:32:33

D'accord ! merci pour ton aide.

A plus tard.

Répondre à Dédé86

7

Dédé86, le 30 mai 2008 à 14:13:54

Re Bonjour

J'ai encore un problème. J'ai la fonction changerCouleur en Javascript qui modifie la couleur d'une textarea lorsque l'utilisateur clique sur une <option> d'un <select> :

function changerCouleur(couleur)
{
document.getElementById('maTextarea').style.backgroundColor=couleur;
}


Je vous épargne les détails du code pour me concentrer sur ce qui ne fonctionne pas. J'envoie à ma fonction le nom de la couleur quand l'événement onclick se déclenche. J'ai mis en gras ce qui ne marche pas.

document.write("<option onclick='changerCouleur(mesCouleurs[i]);' style='background-color:"+ mesCouleurs[i] +";'>"+ mesCouleurs[i] +"</option>");

Lorsque je retire l'argument mesCouleurs[i]), la fonction est appelée. Mais sinon non. Je pense donc que l'erreur vient de guillemets à mettre mais je ne suis pas sûr de la syntaxe.

Pouvez-vous m'aider svp ?

Répondre à Dédé86

8

PhP, le 30 mai 2008 à 16:31:34
  • +1

Bjr


Evidemment car tu as fait une erreur ...
Curieusement tu n'as pas fait l'erreur lorsque tu as écrit style='background-color:"+ mesCouleurs[i] +";'>"

Là c'est bon

En fait il faut bien comprendre qu'une chaîne de caractères reste une chaîne de caractères
Si tu décides de commencer ta chaîne par un guillemet alors elle doit se terminer par un guillemet. Tout ce qui se trouve encadrer par les 2 guillemets n'est pas interprété : c'est du texte pur et dur

Je suppose que la paramètre couleur que tu essais de passer à ta fonction est une châine de caractères par ex "00FF2A"

Donc tu dois écrire

document.write("<option onclick='changerCouleur("+mesCouleurs[i]+");' style='background-color:"+ mesCouleurs[i] +";'>"+ mesCouleurs[i] +"</option>");

Là c'est mieux mais ca ne fonctionne toujours pas : en effet ce que tu dois obtenir c'est

<option onclick='changerCouleur("00FF2A");' >...</option>

et surtout pas (enfin dans ce cas précis il se peut que ça fonctionne mais c'est un coup de chance ...)

<option onclick='changerCouleur(00FF2A);' >...</option> !!!!!!

Donc tu te retrouves dans la situation où tu ne peux utiliser ni une apostrophe ni un guillemet : comment faire alors ?
En utilisant un sequence d'échappement ou escape sequence (pour faire genre ...)

document.write("<option onclick='changerCouleur(\""+mesCouleurs[i]+"\");' style='background-color:"+ mesCouleurs[i] +";'>"+ mesCouleurs[i] +"</option>");

Note le \ devant le " : dans ce cas Javascript considère le guillemet comme faisant partie de la chaîne et non plus comme délimiteur ! Malin non ?

Ex plus simple pour bien comprendre : afficher un message d'alerte avec le mot Aujourd'hui


En encadrant avec des guillemets : no problemo
alert("Aujourd'hui");

En encadrant avec des quotes : la séquence d'échappement est obligatoire !
alert('Aujourd\'hui');

PhP  
Il y a 10 types de personnes dans le monde : ceux qui comprennent le binaire et les autres ...

Répondre à PhP

9

 Dédé86, le 30 mai 2008 à 21:14:57

Merci beaucoup pour ton aide php, les choses me semble plus claires à présent.

A bientôt.

Répondre à Dédé86