本文實例講述了PHP函數rtrim()使用中的怪異現象。分享給大家供大家參考,具體如下:
今天用rtrim()
函數時遇到了一個奇怪的問題:
echo rtrim('<p></p>', '</p>'); // 输出为 <p echo ltrim('www.php.cn','www.'); // 输出为 php.cn
以上的輸出結果有點出乎意料,本來我想第一行應該輸出
,第二行會輸出jb51.net。
這個問題糾結了我好久,一直沒有找到原因,後來在手冊中找到了答案:
rtrim()是以字符為單位替換,而不是以字符串的。從右往左替換時
6個字元肯定會被替換掉的,再往左時遇到了>,因為>也包含在rtirm()的第二個參數的字串(< /p>)中,所以也被替換掉了,當再往左時遇到了p,這時p不包含在第二個參數的字串中。所以替換停止,輸出了如果這樣理解的話,第二行的輸出結果就是在意料之中了。呵呵……手冊中已經寫的清清楚楚了。原文:
You can also specify the characters you want to strip, by means of the charlist parameter. Simply list all characters that you want to be stripped. With .. you can specify a range of you want to be stripped. With .. you can specify a range of characters 。
由此可見,rtrim
、ltrim
與trim
第二個參數是作為一組字元清單進行匹配操作的。這與我們以往所認識的str_replace
函數的替換運算不一樣。
更多PHP函數rtrim()使用中的怪異現象相關文章請關注PHP中文網!