小编从尝试thinkphp框架以来是一位出道的新手,但对于知识的渴望比较强,有一个调用需要用到标题字数超出时,要自动加上省略号,听说在thinkphp模板引擎里可以这样写:{$vo.title|msubstr=0,5,'utf-8′,false} 。函数msubstr它代表的意思是截取字符串$vo.title,从0个字符开始截取,截取5个字符,使用的是utf-8编码,默认截取后不显示省略号,如果要显示省略号,把false改成true就可以。

函数格式:

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

参数功能:

$str:要截取的字符串

$start=0:开始位置,默认从0开始

$length:截取长度

$charset="utf-8":字符编码,默认UTF-8

$suffix=true:是否在截取后的字符后面显示省略号,默认true显示,false为不显示

但写在Thinkcmf模板里是没有该函数的,需要自定义全局应用库函数,可以自行创建如/app/common.php 文件

将以下代码写入即可:

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;

}

PS :代码使用了

标签直接复制即可,不影响内容。

效果如下:

感谢两位作者提供的文章:

thinkPHP内置字符串截取函数用法详解:http://www.jb51.net/article/97315.htm

CMF5自定义函数:https://www.thinkcmf.com/topic/1360.html

php字数超出省略号,thinkcmf 标题字数超出显示省略号 | 速光网络博客相关推荐

  1. li 字多出了省略号_css 超出用省略号当标题字符溢出用省略号表示

    css 超出用省略号当标题字符溢出用省略号表示 发布时间:2013-03-18 14:44:56   作者:佚名   我要评论 文章列表由于标题过长而影响美观度,所以想让标题溢出的文字以省略号方式表现 ...

  2. 安卓超过两行就加省略号_CSS文本超出2行就隐藏并且显示省略号

    超出一行隐藏: overflow:hidden; //超出的文本隐藏 text-overflow:ellipsis; //溢出用省略号显示 white-space:nowrap; //溢出不换行 但是 ...

  3. 单行文本溢出显示省略号,单行文本溢出显示省略号

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  4. CSS文本超出2行就隐藏并且显示省略号

    超出一行隐藏: overflow:hidden; //超出的文本隐藏 text-overflow:ellipsis; //溢出用省略号显示 white-space:nowrap; //溢出不换行 但是 ...

  5. 知识点------文字超出(单行,两行)显示省略号(...)

    文字超出单行不换行,显示省略号 .word {overflow: hidden;text-overflow: ellipsis;white-space: nowrap; --------------- ...

  6. li 字多出了省略号_文字溢出自动显示省略号css方法 -

    文字样式(Text Style)是一组可随图形保存的文字设置的集合,这些设置可包括字体设置以及特殊效果等.文字样式在不同的软件环境下显示的方式也会不一样.下面就来分享一下html中如何让文字竖排?总结 ...

  7. li 字多出了省略号_文字溢出自动显示省略号css方法

    这次给大家带来文字溢出自动显示省略号css方法,文字溢出自动显示省略号css的注意事项有哪些,下面就是实战案例,一起来看一下. 我们经常会遇到文字太多,而为了不打破原有布局,需要将多出文字用省略号代替 ...

  8. 标题文字超出2行 则隐藏后面显示省略号

    css小技巧 overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: 2;-webkit-b ...

  9. css 文本超出2行就隐藏并且显示省略号

    今天做东西,遇到了这个问题,百度后总结得到了这个结果. 首先,要知道css的三条属性. overflow:hidden; //超出的文本隐藏 text-overflow:ellipsis; //溢出用 ...

最新文章

  1. 利用“哨兵”“实现双链表
  2. 2019.7.9 校内测试题 史密斯数
  3. Spring5源码 - 02 Bean和Java对象的区别与猜想验证BeanDefinition
  4. SAP ABAP逻辑数据库
  5. mysql window怎么安装补丁_window下mysql安装步骤
  6. 成为一名JAVA高级工程师你需要学什么
  7. android原生webview,Android 原生与WebView JS的交互
  8. JS任务队列--笔记
  9. jquery 动态加载html,jQuery – 动态创建iframe并加载页面
  10. superset docker 部署
  11. Java集合框架知多少——干货!!!
  12. CCS Product ****** is not currently installed and no compatible version is available 报错调试
  13. mybatis 使用简单的增删查改
  14. 大数据驱动教育变革,产教融合呈现新高度——数据科学与大数据技术教育分论坛顺利召开...
  15. Apm飞控学习笔记之-电机解锁和故障保护-Cxm
  16. 首支完全由 AI 创作的歌曲《未来之歌》发布!对于未来,你方了吗?
  17. 虚拟机(VM)与JVM
  18. 2019年(本命年)个人总结
  19. 3.SVN服务器与客户端基本使用
  20. 桂电七院数据库实验报告四

热门文章

  1. 漫步者耳机看网页版视频自动关机
  2. Messari分析师:交易量优势表明Perpetual Protocol盈利潜力巨大
  3. ReactNative中使用FlatList
  4. python编程界面-Python可视化界面编程入门
  5. [C++11] auto关键字详解
  6. 说一下R语言的strptime()及衍生的一些时间序列的格式及使用问题
  7. 使用 Python 操作 Evernote API
  8. ipad分屏功能怎么用_用iPad真的可以提高学习效率么?怎么把iPad变成生产力?
  9. ffmpeg 视频实现各种特效
  10. ANDROID物联网开发