A-A+

Phpcms V9截取字符函数的优化

2015年03月26日 编程技术 暂无评论

phpcms v9 中截取字符的函数是 str_cut(),截取字符在读取文章列表时用的是比较多的,有的文章标题太长,如果不进行截取的话就会产生下一行的文字,看起来很难看的说,虽说 phpcms v9 的str_cut() 函数基本可以满足需求,但其长度的精度并不准确,尤其是对于中英文字符混搭的时候就更不准确了,小虎博客在使用中,往往因为字符长度的问题搞得页面好不美观。

在网上搜索了一段改进 str_cut 函数的代码,可以将其长度的精准偏差在 2 个字符之内,感觉不错,特分享出来,实例代码如下:

[code lang="php"]
/**
* 字符截取 支持UTF8/GBK
* @param $string
* @param $length
* @param $dot
*/
function str_cut($string, $length, $dot = '') {
$strlen = strlen($string);
if($strlen/2 <= $length) return $string;
$string = str_replace(array(' ',' ',' ',' ', '&', '"', ''', '“', '”', '—', '<', '>', '·', '…'), array(' ',' ',' ',' ', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), $string);
$strcut = '';
$n = $tn = $noc = 0;
if(strtolower(CHARSET) == 'utf-8') {
while($n < $strlen) {
$t = ord($string[$n]);
if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
$tn = 1; ++$n; $noc += 0.5;
} elseif(194 <= $t && $t <= 223) {
$tn = 2; $n += 2; $noc += 1;
} elseif(224 <= $t && $t <= 239) {
$tn = 3; $n += 3; $noc += 1;
} elseif(240 <= $t && $t <= 247) {
$tn = 4; $n += 4; $noc += 1;
} elseif(248 <= $t && $t <= 251) {
$tn = 5; $n += 5; $noc += 1;
} elseif($t == 252 || $t == 253) {
$tn = 6; $n += 6; $noc += 1;
} else {
++$n;
}
if($noc >= $length) {
if($n < $strlen) ++$noc;
break;
}
}
} else {
while($n < $strlen) {
if(ord($string[$n]) > 127) {
$tn = 2; $n += 2; $noc += 1;
} else{
$tn = 1; ++$n; $noc += 0.5;
}
if($noc >= $length) {
if($n < $strlen) ++$noc;
break;
}
}
}
if($noc > $length && !empty($dot)) {
$n -= $tn;
$strcut = substr($string, 0, $n);
$strcut .= $dot;
}else{
$strcut = substr($string, 0, $n);
}
$strcut = str_replace(array('&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), array('&', '"', ''', '“', '”', '—', '<', '>', '·', '…'), $strcut);
return $strcut;
}
[/code]

这样再进行截取中英文混搭字符的时候,就不会出现长度太大的偏差了,当然,如果你的站点是纯英文站或者是纯中文站的话,就没必要去改进这个函数了。

标签:

给我留言