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

Langage PHP Discussion :

[PHP-JS] Chaînes HTML à partir de BDD (apostrophe et guillements)


Sujet :

Langage PHP

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    109
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 109
    Par défaut [PHP-JS] Chaînes HTML à partir de BDD (apostrophe et guillements)
    Bonjour,

    Je suis désolée de poser une question aussi bête... sur plein de forum il y a des solutions mais aucune ne marche.

    Voilà, je reprend une application php existante où des personnes ont ajouté du texte dans la bdd mysql dans la table commentaires.

    Je souhaite afficher un tableau et lorsqu'on clique sur une cellule, on affiche le commentaire associé.

    Je recupere mon commentaire dans ma bdd:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    while ($row = mysql_fetch_assoc ($res))
    	{
    	$commentaireSansImpact.= FONCTIONQUIMANQUE($row["commentaire"]).' </br>';
    					}
    il peut etre de la forme
    Août 2007 : contrat NOK sur le critère "Temps ". Une action est engagée pour améliorer l'ensemble des temps de réponse.

    Voici mon code de la cellule:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <td align="center" id="c<?=$i.$j?>"> 
      <A style="cursor:pointer" onClick="ChangeMessage('<?=$commentaireSansImpact?>','ejs_texte');" ><?=$texteCellule?></A>	 
    </td>
    Voici mon javascript:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    function ChangeMessage(message,champ)
      {
      if(document.getElementById)
        document.getElementById(champ).innerHTML = message;
      }
    Voici où est ajouté mon commentaire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <DIV ID=ejs_texte></DIV>

    Bon le soucis est que dans la bdd, il peut avoir du texte avec des guillements, avec des cotes (ou les deux), et que meme si j'utilise addslashes(), nl2br(),htmlspecialchars() ou htmlentities(), ou meme un mixe de toutes je n'arrive pas à afficher le commentaire parfois. C'est à dire, je clic et il ne s'affiche pas pour certaines cellules ou alors pire c'est juste affiché dans la cellule elle meme ','ejs_texte');" >

    Comment fait on pour passer à une fonction javascript, une chaine à afficher dans du html à partir d'une bdd où il y a des guillements ET des appostrophes?

    Merci d'avance

  2. #2
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Bonjour

    J'ai un peu du mal à voir quel est ton problème. Pourrais-tu donner un peu plus de précisions sur ce que tu attends de nous ?
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    109
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 109
    Par défaut
    Désolée, c'était pas très clair, j'ai modifié mon post initial:

    C'est plus clair avec la question:
    Comment fait on pour passer en php à une fonction javascript, une chaine à afficher dans du html à partir d'une bdd où il y a des guillements ET des appostrophes?

    Lol

    Je n'arrive pas à utiliser une fonction (ou des fonctions) qui me permettent de formater mon commentaire de la bdd pour le passer à la fonction javascript pour qu'il le mette dans le innerHTML d'une div de ma page...

    C'est un peu plus clair?
    Merci de ton aide

  4. #4
    Modératrice
    Avatar de Celira
    Femme Profil pro
    Développeuse PHP/Java
    Inscrit en
    Avril 2007
    Messages
    8 633
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeuse PHP/Java
    Secteur : Industrie

    Informations forums :
    Inscription : Avril 2007
    Messages : 8 633
    Par défaut
    Bon, c'est effectivement mieux comme ça

    Normalement, la fonction htmlentities devrait faire l'affaire surtout si tu utilises la propriété ENT_QUOTES.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    while ($row = mysql_fetch_assoc ($res))
    {
    	$commentaireSansImpact.= htmlentities($row["commentaire"], ENT_QUOTES).' </br>';
    }
    Modératrice PHP
    Aucun navigateur ne propose d'extension boule-de-cristal : postez votre code et vos messages d'erreurs. (Rappel : "ça ne marche pas" n'est pas un message d'erreur)
    Cherchez un peu avant poser votre question : Cours et Tutoriels PHP - FAQ PHP - PDO une soupe et au lit !.

    Affichez votre code en couleurs : [CODE=php][/CODE] (bouton # de l'éditeur) et [C=php][/C]

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2005
    Messages
    109
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2005
    Messages : 109
    Par défaut
    Merci de ta réponse mais ça ne marche pas mieux

    Lorsque je clic sur certaines cases, rien ne se passe.

    Pour debugger j'ai mis un alert dans le javascript et en fait celui ci n'est pas appelé lorsque mon texte contient des cotes.

    Si je fais un echo de ma ligne, je suis bien sensée trouver affiché sur ma page les apostrophes directement ?
    en mettant
    echo htmlentities(htmlentities($row["commentaire"], ENT_QUOTES), ENT_QUOTES); j'ai & # 0 3 9 ; à la place mais ça marche pas mieux....

    J'ai fais un essai $row["commentaire"]="texte avec guillement \' et cotes \" et voilà"; Et en rajoutant le htmlentities ça marche mais dès que je remplace par
    $row["commentaire"]=addslashes($row["commentaire"]; ça marche plus.

    J'ai essayé tout et n'importe quoi et je vois pas pour l'instant une solution qui marche...

    Le problème vient donc que ma fonction javascript n'arrive pas à être appellée lorsque mon texte regroupe cotes et guillements

  6. #6
    Membre éprouvé Avatar de Grepsd
    Homme Profil pro
    Développeur Web
    Inscrit en
    Octobre 2008
    Messages
    96
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Octobre 2008
    Messages : 96
    Par défaut
    Un double htmlentities ne t'aidera pas.

    Regarde le code source de la page générée via ton navigateur web et regarde si le code JavaScript est toujours correct.

    N'oublis pas également que tu peux détecter les erreurs de JavaScript via les consoles des différentes navigateurs(FireFox->Outils->Console d'erreurs par exemple)

    Si ça ne fonctionne toujours pas, pourrais tu nous copier le HTML géneré qui ne fonctionne pas ?

    Merci.

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

Discussions similaires

  1. creer des fichier html à partir de fichier php
    Par nicerico dans le forum Langage
    Réponses: 5
    Dernier message: 12/07/2010, 12h36
  2. Réponses: 6
    Dernier message: 12/09/2006, 17h31
  3. [DOM]Créer dynamiquement du HTML à partir d'une chaîne
    Par jothi35 dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 11/08/2006, 20h01
  4. PHP -- MYSQL -- Formulaire HTML
    Par waybee dans le forum Requêtes
    Réponses: 2
    Dernier message: 28/11/2005, 09h30
  5. [SGBD] afficher infos issues de php/mysql dans html
    Par php_de_travers dans le forum Requêtes
    Réponses: 11
    Dernier message: 22/10/2005, 00h28

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