Textarea - 缺少新行

Posted

技术标签:

【中文标题】Textarea - 缺少新行【英文标题】:Textarea - missing new line 【发布时间】:2014-04-03 18:41:56 【问题描述】:

我有以下代码:

<form action="../p/padd.php" method="POST"> 
<input type="button" value="Náhľad"  OnClick="javascript:nahlad()" /> 
<textarea tabindex="4" id="textra" name="text" ></textarea>
<input type="submit" value="Vložiť" /> 
</form>

<span id="nahlad"> </span>

<script>
   function nahlad()
   
     var textra = document.getElementById("textra").value;
     alert (textra);
     var xmlhttp;
     if (window.XMLHttpRequest) xmlhttp=new XMLHttpRequest();
   
   else
     xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
   xmlhttp.onreadystatechange=function()
   
   if (xmlhttp.readyState==4 && xmlhttp.status==200) 
   
     document.getElementById('nahlad').innerhtml = xmlhttp.responseText;
   
  
xmlhttp.open("GET","ssnahlad.php?text=" + textra,true);
xmlhttp.send();

</script>

当我在 textarea 中输入以下内容时(是的,输入时有“新行”)

asd
asd

然后点击 Nahlad 按钮

ssnahlad.php 包含

<?php
$new = $_GET['text'];
echo nl2br($new);
?>

那么为什么 id=nahlad 的 span 包含

asdasd 

而不是

asd
asd  

【问题讨论】:

在使用 ajax 发送之前,您可能需要对其进行编码。你可以在发送之前提醒 textra 的值,看看你得到了什么,可能是“asdasd” 警报(文本);工作正常。没有问题 包含$_GET['text']; 换行符号\r\n\n 或类似的或仅包含asdasd??尝试使用var_dump() 进行检查 字符串“asdasd”(长度=6) 【参考方案1】:

现在我在家并且可以测试,这将起作用:

  var newText = encodeURIComponent(textra);

在发送之前使用encodeURIComponent 将正确呈现您的输出,而在服务器端没有解码

【讨论】:

你这样做的原因是什么? 我有 textra,用户在其中输入文本,我向他展示它在页面上的外观,我也需要使用新行,对于某些用户来说,很难记住 html 代码来创建新行...这只是代码的一部分,但有错误 谢谢,抱歉耽搁了一段时间;我讨厌试图用手机回答问题。一旦我回到家,它就变得很容易修复。

以上是关于Textarea - 缺少新行的主要内容,如果未能解决你的问题,请参考以下文章

textarea 中的新行在 IE 中不起作用

如何使用javascript在textarea中添加新行

php :: textarea 中的新行?

Angular2使textarea按Enter而不添加新行

按下 ENTER 时禁用 Textarea 中的新行

如何检测“shift+enter”并在 Textarea 中生成新行?