Thinkphpテンプレート中国語文字列関数の切り取り


thinkphpテンプレートが中国語文字列コードをどのように切り取るかプロジェクトの開発では、ニュースリストページにニュースコンテンツの概要が必要ななど、中国語文字列の切り取り問題がよく発生します.これは文字列切り取りに使用されます.次に、カプセル化された文字列切り取り関数を共有します.//関数の説明://msubstr($str,$start=0,$length,$charset="utf-8",$suffix=true)//$str:切り取る文字列//$start=0:開始位置、デフォルトは0から//$length:$charset="utf-8":文字コード、デフォルトUTF-//$suffix=true:切り取った文字の後ろに省略記号を表示するかどうか、デフォルトtrue表示、falseは//テンプレートを表示しないために使用します:{$vo.title|msubst=0,5,'utf-8',false}thinkphpコアパッケージの/common/functionsに次のコードを貼り付けます.phpの最後はhtmlモデルで直接使用できます
function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)  
    {  
  if(function_exists("mb_substr")){  
              if($suffix)  
              return mb_substr($str, $start, $length, $charset)."...";  
              else
                   return mb_substr($str, $start, $length, $charset);  
         }  
         elseif(function_exists('iconv_substr')) {  
             if($suffix)  
                  return iconv_substr($str,$start,$length,$charset)."...";  
             else
                  return iconv_substr($str,$start,$length,$charset);  
         }  
         $re['utf-8']   = "/[x01-x7f]|[xc2-xdf][x80-xbf]|[xe0-xef]
                  [x80-xbf]{2}|[xf0-xff][x80-xbf]{3}/";  
         $re['gb2312'] = "/[x01-x7f]|[xb0-xf7][xa0-xfe]/";  
         $re['gbk']    = "/[x01-x7f]|[x81-xfe][x40-xfe]/";  
         $re['big5']   = "/[x01-x7f]|[x81-xfe]([x40-x7e]|xa1-xfe])/";  
         preg_match_all($re[$charset], $str, $match);  
         $slice = join("",array_slice($match[0], $start, $length));  
         if($suffix) return $slice."…";  
         return $slice;
    }