php字数超出省略号,thinkcmf 标题字数超出显示省略号 | 速光网络博客
小编从尝试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 标题字数超出显示省略号 | 速光网络博客相关推荐
- li 字多出了省略号_css 超出用省略号当标题字符溢出用省略号表示
css 超出用省略号当标题字符溢出用省略号表示 发布时间:2013-03-18 14:44:56 作者:佚名 我要评论 文章列表由于标题过长而影响美观度,所以想让标题溢出的文字以省略号方式表现 ...
- 安卓超过两行就加省略号_CSS文本超出2行就隐藏并且显示省略号
超出一行隐藏: overflow:hidden; //超出的文本隐藏 text-overflow:ellipsis; //溢出用省略号显示 white-space:nowrap; //溢出不换行 但是 ...
- 单行文本溢出显示省略号,单行文本溢出显示省略号
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- CSS文本超出2行就隐藏并且显示省略号
超出一行隐藏: overflow:hidden; //超出的文本隐藏 text-overflow:ellipsis; //溢出用省略号显示 white-space:nowrap; //溢出不换行 但是 ...
- 知识点------文字超出(单行,两行)显示省略号(...)
文字超出单行不换行,显示省略号 .word {overflow: hidden;text-overflow: ellipsis;white-space: nowrap; --------------- ...
- li 字多出了省略号_文字溢出自动显示省略号css方法 -
文字样式(Text Style)是一组可随图形保存的文字设置的集合,这些设置可包括字体设置以及特殊效果等.文字样式在不同的软件环境下显示的方式也会不一样.下面就来分享一下html中如何让文字竖排?总结 ...
- li 字多出了省略号_文字溢出自动显示省略号css方法
这次给大家带来文字溢出自动显示省略号css方法,文字溢出自动显示省略号css的注意事项有哪些,下面就是实战案例,一起来看一下. 我们经常会遇到文字太多,而为了不打破原有布局,需要将多出文字用省略号代替 ...
- 标题文字超出2行 则隐藏后面显示省略号
css小技巧 overflow: hidden;text-overflow: ellipsis;display: -webkit-box;-webkit-line-clamp: 2;-webkit-b ...
- css 文本超出2行就隐藏并且显示省略号
今天做东西,遇到了这个问题,百度后总结得到了这个结果. 首先,要知道css的三条属性. overflow:hidden; //超出的文本隐藏 text-overflow:ellipsis; //溢出用 ...
最新文章
- 利用“哨兵”“实现双链表
- 2019.7.9 校内测试题 史密斯数
- Spring5源码 - 02 Bean和Java对象的区别与猜想验证BeanDefinition
- SAP ABAP逻辑数据库
- mysql window怎么安装补丁_window下mysql安装步骤
- 成为一名JAVA高级工程师你需要学什么
- android原生webview,Android 原生与WebView JS的交互
- JS任务队列--笔记
- jquery 动态加载html,jQuery – 动态创建iframe并加载页面
- superset docker 部署
- Java集合框架知多少——干货!!!
- CCS Product ****** is not currently installed and no compatible version is available 报错调试
- mybatis 使用简单的增删查改
- 大数据驱动教育变革,产教融合呈现新高度——数据科学与大数据技术教育分论坛顺利召开...
- Apm飞控学习笔记之-电机解锁和故障保护-Cxm
- 首支完全由 AI 创作的歌曲《未来之歌》发布!对于未来,你方了吗?
- 虚拟机(VM)与JVM
- 2019年(本命年)个人总结
- 3.SVN服务器与客户端基本使用
- 桂电七院数据库实验报告四