|
|
|
|
Matt, le lundi 24 septembre 2007 à 19:41:24Salut,
utilise str_replace('<br/>', "\n", $text) forum spécialisé php : http://www.phpcs.com Bonne continuation |
Merci mais, j'ai déja essayé et ca ne change rien ... les <br /> sont toujours là...
Voici mon code : <textarea name="modifenqqmpar1" wrap="physical" id="champs1" > <?php $text = include("../texte/pconnexion/enqqmpar1.txt"); str_replace('<br/>', "\n", $text); echo $text; ?> </textarea> Cela est peut-être du au fait que j'attribue la valeur de ma commande include à ma variable $text ??? |
Bien sur !
Include ne renvoi pas le contenu du fichier dans la variable, il est directement interprété et/ou envoyé au navigateur. cf ( http://www.php.net/manual/fr/function.include.php ) Pour récupérer le contenu d'un fichier il faut utiliser file_get_contents ( http://www.php.net/manual/fr/function.file-get-contents.php ) |
il y a aussi des chances que tu vois <br /> affiche mais qu'en réalite ce soit htmlentities("<br />") donc adapte ton str8replace en fonction de ca |
IL ME SEMBLE DE MEMOIRE QUE LE FICHIERS .txt ne gere pas les retour charriots remplace le par un .php |
la balise <pre> permet d'effectuer un retour chariot automatique et il ny a donc pas besoin de <br />.
tu place la balise <pre> au début de ta textarea et a la fin et quan un retour a la ligne, un saut de ligne... sera effectuer dans la textarea, il sera effectuer dans le fichier texte quan il aura été écrit dedans. mai je te conseille, de remplacer ton fichier texte par un fichier php.
|
En effet, cela fonctionne avec un simple str_replace('<br />','',$text), mais il faut qu'il soit combiné avec un nl2br(htmlentities($_POST["nom de ton textarea"])) à la réception de la modification. Il te faut donc deux scripts.
exemple : Modifier.php : <? $serveur=""; $bdd_login=""; $bdd_psw=""; $bdd=$bdd_login; $db = mysql_connect($serveur,$bdd_login,$bdd_psw) or die ("Erreur 1 dans modifier.php :".mysql_error()); mysql_select_db($bdd,$db) or die ("Erreur 2 dans modifier.php :".mysql_error()); if(isset(htmlentities($_POST["description"]))){ $description=nl2br(htmlentities($_POST["description"])); mysql_query("UPDATE `MaTable` SET `description` = '$description' WHERE pseudo = 'MonPseudo' LIMIT 1 ") or die("Erreur 2 dans modifier.php :".mysql_error());// } $req = mysql_query("SELECT * FROM MaTable WHERE pseudo='MonPseudo'") or die(mysql_error()); $contenu = mysql_fetch_array($req); ?> <html> <body> <Form action="" method="post"> <textarea name="description" cols="35" rows="10" id="textarea"> <? print str_replace('<br />','',$contenu["description"]);?> </textarea> <input type="button" value="Enregistrer"> </form> </body> </html> <? mysql_close();?> |
Bonjour
Le problème, c'est que tu enregistres dans ta base un texte différent de celui que l'utilisateur à frappé. Quand tu enregistres nl2br(htmlentities($_POST["description"])), ton texte est altéré. Il faut enregistrer dans ta base mysql_real_escape_string($_POST["description"]) pour avoir le 'vrai' texte dans ta base. Plus tard, quand tu le récupères dans une variable $texte grâce à une requête, tu peux l'afficher : . dans un TEXTAREA grâce à htmlentities($texte) . hors TEXTAREA grâce à un nl2br(htmlentities($texte)) |