|
<?php
$lenth = 19;
$str = "怎么將新聞的很長(zhǎng)的標(biāo)題只顯示前面一些字,后面用.....來(lái)代替?";
echo strlen($str)<=$lenth ? $str : (substr($str,0,$lenth).chr(0)."....");
?>
復(fù)制代碼 代碼如下:
<?
/*
@ 另一種方法,使用ord()函數(shù):
@ 適用于 gb2312 編碼:
*/
$str = "怎么將新聞的很長(zhǎng)的標(biāo)題只顯示前面一些字,后面用.....來(lái)代替?";
function gb2312_substr($str, $limit) {
$restr ='';
for($i=0;$i< $limit-3;$i++) {
$restr .= ord($str[$i])>127 ? $str[$i].$str[++$i] : $str[$i];
}
return $restr;
}
/*
@ 以下僅適用于 utf-8 編碼;
*/
function utf8_substr($str, $limit) {
$restr = '';
for($i=0;$i< $limit-3;$i++) {
$restr .= ord($str[$i])>127 ? $str[$i].$str[++$i].$str[++$i] : $str[$i];
}
return $restr;
}
//解釋下上面第一個(gè):chr(0)不是null,null是什么都沒(méi)有,而chr(0)的值是0。表示成16進(jìn)制是0x00,表示成二進(jìn)制是00000000雖然chr(0)不會(huì)顯示出什么,但是他是一個(gè)字符。雖然chr(0)不會(huì)顯示出什么,但是他是一個(gè)字符。當(dāng)漢字被截?cái)鄷r(shí),根據(jù)編碼規(guī)則他總是要把后邊的其他字符拉過(guò)來(lái)一起作為漢字解釋?zhuān)@就是出現(xiàn)亂碼的原因。
?>
php技術(shù):php chr() ord()中文截取亂碼問(wèn)題解決方法,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。