thinkcmf5截取字符 |msubstr函数 mb_substr()


thinkcmf5已经移除了msubstr()函数;如有字符截取需求,请按以下方法


前端使用方法

{$vo.xxxx|msubstr=0,5 }

{$vo.xxxx|msubstr=0,5,utf-8,false }

{$vo.xxxx|msubstr=0,5,utf-8,false }


====================================================

thinkcmf5 公共方法路径simplewind\cmf\common.php

将下面方法复制进去就可以使用了


  1. function msubstr($str, $start=0, $length, $charset="utf-8", $suffix=true)  

  2.     {  

  3.   if(function_exists("mb_substr")){  

  4.               if($suffix)  

  5.               return mb_substr($str, $start, $length, $charset)."...";  

  6.               else

  7.                    return mb_substr($str, $start, $length, $charset);  

  8.          }  

  9.          elseif(function_exists('iconv_substr')) {  

  10.              if($suffix)  

  11.                   return iconv_substr($str,$start,$length,$charset)."...";  

  12.              else

  13.                   return iconv_substr($str,$start,$length,$charset);  

  14.          }  

  15.          $re['utf-8']   = "/[x01-x7f]|[xc2-xdf][x80-xbf]|[xe0-xef]

  16.                   [x80-xbf]{2}|[xf0-xff][x80-xbf]{3}/";  

  17.          $re['gb2312'] = "/[x01-x7f]|[xb0-xf7][xa0-xfe]/";  

  18.          $re['gbk']    = "/[x01-x7f]|[x81-xfe][x40-xfe]/";  

  19.          $re['big5']   = "/[x01-x7f]|[x81-xfe]([x40-x7e]|xa1-xfe])/";  

  20.          preg_match_all($re[$charset], $str, $match);  

  21.          $slice = join("",array_slice($match[0], $start, $length));  

  22.          if($suffix) return $slice."…";  

  23.          return $slice;

  24.     }






项目开发中,常常会遇到中文字符串截取问题,比如说新闻列表页面需要新闻内容简介,这就要用到字符串截取了。下面我就给大家分享一个已经封装好的字符串截取函数。
//函数解释:
//msubstr($str, $start=0, $length, $charset=”utf-8″, $suffix=true)
//$str:要截取的字符串
// $start=0:开始位置,默认从0开始
// $length:截取长度
// $charset=”utf-8″:字符编码,默认UTF-8
// $suffix=true:是否在截取后的字符后面显示省略号,默认true显示,false为不显示
//模版使用:{$vo.title|msubstr=0,5,'utf-8',false}
把如下代码粘贴到thinkphp核心包的/common/functions.php 的最后便可在html模型里直接使用