[英]textarea not providing html tags
這可能是一個非常簡單而愚蠢的問題,但它是如此簡單以至於我不知道自己做錯了什么。
我正在嘗試獲取文本區域的內容,同時保留格式(折線,空格等)。 但是,當我嘗試發布表單時,找不到html標記。 我所得到的只是純文本。
當我這樣輸入文本區域時:
first line
after 3 br
我期望echo $foo;
的結果echo $foo;
是這樣的:
first line
<br/>gt;
<br/>gt;
<br/>gt;
after 3 br
但是,而是echo $foo;
的結果echo $foo;
仍然是這樣的:
first line
after 3 br
這是display.php
:
<form method="post" action="">
<textarea name="foo"><?php echo set_value('foo'); ?></textarea>
<br/>
<input type="submit" name="submit" value="Submit"/>
</form>
這是控制器:
function form_foo()
{
$foo = $this->input->post('foo');
if (get_magic_quotes_gpc())
{
$foo = stripslashes($foo);
}
$foo = htmlentities($foo);
echo $foo;
$this->load->view('display', $this->data);
}
我做錯了什么?
PS:我正在使用codeigniter 3.0和PHP 5.6.15
試試這個代碼-
function form_foo()
{
$foo = $this->input->post('foo');
if (get_magic_quotes_gpc())
{
$foo = stripslashes($foo);
}
//$foo = htmlentities($foo);
echo $foo;
$this->load->view('display', $this->data);
}
您為什么不使用contenteditable
?
<div contenteditable="true"></div>
這可以將<div>
變為可編輯區域,但沒有樣式。 您需要另外設置樣式。
這是我的CSS解決方案
[contentEditable=true] {
white-space: pre;
background-color: #FFFFFF;
min-height: 6em;
max-height: 12em;
overflow-y: scroll;
outline: none !important;
border-radius: 4px;
padding: 4px;
}
小心處理HTML標記。
請參閱參考內容 。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.