php表單轉(zhuǎn)換textarea換行符的方法
下面是我對這個(gè)問題的解決過程,最后算是完全搞懂了,真是陰溝里險(xiǎn)些翻船
1.必須知道textarea中的換行符是 \n (個(gè)人檢測發(fā)現(xiàn)按回車鍵是\n,好像在linux下是\r\n)
2.用nl2br之前,請仔細(xì)看好手冊解釋,我就是搞郁悶了,一般都理解為將\n轉(zhuǎn)換成<br >,其實(shí)不是的:
看php手冊解釋:
nl2br – Inserts HTML line breaks before all newlines in a string
Returns string with ‘<br />' inserted before all newlines
意思是說在 新的一行前插入<br />
w3cschool上的說法是:
nl2br() 函數(shù)在字符串中的每個(gè)新行 (\n) 之前插入 HTML 換行符 (<br />)。
所以nl2br()能夠插入<br> 但 \n 依舊存在,比如說 字符串源碼是:程序\n生活網(wǎng),我們nl2br 之后就是 程序<br>\n生活網(wǎng) 所以我們看到的效果將是
程序
生活網(wǎng)———————-換行了,因?yàn)樵创a中還有\(zhòng)n
3.用php函數(shù),str_replace替換函數(shù),比如str_replace(‘\n','<br />') ,問題是替換并沒有成功,一直都沒有替換掉,我弄了好久甚至開始懷疑textarea中的換行符是不是\n,現(xiàn)在想想真是太動搖了,o(∩_∩)o… 其實(shí)我經(jīng)過測 分別替換 \n /n 后直覺告訴我自己走進(jìn)了死胡同,這不是解決問題的方式,肯定有哪里存在根本性錯(cuò)誤。突然我想到了會不會是單引號或者雙引號的問題呢,于是將str_replace(‘\n','<br />') 改成str_replace(“\n”,”<br />”),靈光閃現(xiàn)了,替換成功。巨汗!
又打開手冊把單引號和雙引號再看了一遍,最后長嘆了一口氣,還是自己基礎(chǔ)的問題啊,php隨簡單,還是要注意細(xì)節(jié)啊。
手冊中關(guān)于單雙引號的解釋很詳細(xì):
單引號
指定一個(gè)簡單字符串的最簡單的方法是用單引號(字符 ‘)括起來。
要表示一個(gè)單引號,需要用反斜線(\)轉(zhuǎn)義,和很多其它語言一樣。如果在單引號之前或字符串結(jié)尾需要出現(xiàn)一個(gè)反斜線,需要用兩個(gè)反斜線表示。注意如果你試圖轉(zhuǎn)義任何其它字符,反斜線本身也會被顯示出來!所以通常不需要轉(zhuǎn)義反斜線本身。
————–所以我們用str_replace(‘\n','<br />')替換的 字符串中的 \n 而不是換行符,似乎有些暈。也就是說單引號內(nèi)的是字符串,php不做任何解釋,這其實(shí)在別的地方用的時(shí)候都知道,但沒想到連換行符都不解釋。
雙引號
如果用雙引號(”)括起字符串,PHP 懂得更多特殊字符的轉(zhuǎn)義序列:
表格 6-1. 轉(zhuǎn)義字符
序列
含義
\n
換行(LF 或 ASCII 字符 0×0A(10))
\r
回車(CR 或 ASCII 字符 0×0D(13))
\t
水平制表符(HT 或 ASCII 字符 0×09(9))
\\
反斜線
\$
美元符號
\”
雙引號
\[0-7]{1,3}
此正則表達(dá)式序列匹配一個(gè)用八進(jìn)制符號表示的字符
\x[0-9A-Fa-f]{1,2}
此正則表達(dá)式序列匹配一個(gè)用十六進(jìn)制符號表示的字符
此外,如果試圖轉(zhuǎn)義任何其它字符,反斜線本身也會被顯示出來!
———這下textarea換行的問題明了了,不是換行符的問題,也不是nl2br的問題,是所有的轉(zhuǎn)移只存在雙引號中,單引號在php中只做字符處理。多么郁悶的錯(cuò)誤啊。以后一定的牢記。
這句有問題:經(jīng)過我的測試,在windows下是\r\n,在linux才是\n(這個(gè)沒實(shí)測),另外,在win下,\r,\n均有換行的功能...
相關(guān)文章
PHP+Mysql+jQuery實(shí)現(xiàn)發(fā)布微博程序 jQuery篇
我們在QQ個(gè)人中心或者新浪微博等網(wǎng)站上可以看到一個(gè)發(fā)表話題的應(yīng)用2011-10-10原生PHP實(shí)現(xiàn)導(dǎo)出csv格式Excel文件的方法示例【附源碼下載】
這篇文章主要介紹了原生PHP實(shí)現(xiàn)導(dǎo)出csv格式Excel文件的方法,結(jié)合實(shí)例形式分析了基于原生php實(shí)現(xiàn)的Excel文件操作類進(jìn)行Excel文件的導(dǎo)出操作相關(guān)實(shí)現(xiàn)技巧,并附帶源碼供讀者下載參考,需要的朋友可以參考下2019-03-03php自定義函數(shù)轉(zhuǎn)換html標(biāo)簽示例
這篇文章主要介紹了php自定義函數(shù)轉(zhuǎn)換html標(biāo)簽的方法,結(jié)合實(shí)例形式分析了php針對字符串的編碼轉(zhuǎn)換與正則替換操作技巧,需要的朋友可以參考下2016-09-09php similar_text()函數(shù)的定義和用法
下面小編就為大家?guī)硪黄猵hp similar_text()函數(shù)的定義和用法。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05