【转】SMARTY 不乱码截取中文

<?php
/*SMARTY 不乱码截取中文

使用方法:把文件命名为:modifier.cn_cut.php 放在smarty下的plugins目录下,第二个参数是如果有截掉部分,那么后面会加后缀,第三个参数是页面的charset.
{$string|cn_cut:10:'...'} 第一个参数是必填,其他是可选.
*/
function smarty_modifier_cn_cut($string, $length = 80, $etc = '', $code = 'UTF-8'){
    if ($length == 0)
        return '';
    if ($code == 'UTF-8') {
        $pa = "/[\x01-\x7f]|[\xc2-\xdf][\x80-\xbf]|\xe0[\xa0-\xbf][\x80-\xbf]|[\xe1-\xef][\x80-\xbf][\x80-\xbf]|\xf0[\x90-\xbf][\x80-\xbf][\x80-\xbf]|[\xf1-\xf7][\x80-\xbf][\x80-\xbf][\x80-\xbf]/";
    }else {
    $pa = "/[\x01-\x7f]|[\xa1-\xff][\xa1-\xff]/";
    }
    preg_match_all($pa, $string, $t_string);
    if (count($t_string[0]) > $length)
        return join('', array_slice($t_string[0], 0, $length)) . $etc;
    return join('', array_slice($t_string[0], 0, $length));
}
?>

posted @ 2013-03-18 11:36  kiter  阅读(620)  评论(0编辑  收藏  举报