wordpress截取文章摘要标题的五种方法

一、wp_trim_words函数

专门用来截取限定字数的内容,比如文章、摘要、标题等

被截取的可以是get_the_title()get_the_content();

  1. <?php echo wp_trim_words( $title,20,'...'); ?>
  1. <? echo wp_trim_words( get_the_title(),38,"..." ); ?>

通过该函数截取文章内容:

  1. <?php
  2.  $content = get_the_content();
  3.  $trimmed_content = wp_trim_words( $content, 40, '<a href="'. get_permalink() .'"> ...Read More</a>' );
  4.  echo $trimmed_content;
  5. ?>

截取设定字数标题:

  1. <?php
  2. 	$title = get_the_title();
  3. 	$trimmed_title = wp_trim_words( $title, 20, '...' );
  4. 	echo $trimmed_title;
  5. ?>

二、PHP文章截断函数mb_strimwidth

mb_strimwidth()是php的函数,所以不依赖wp的版本

1、限制文章标题文字个数

文章标题的调用函数一般是这样:

  1. <?php the_title(); ?>
  1. <?php echo mb_strimwidth(get_the_title(), 0, 36,"..."); ?>

其中 36 代表 18 个双字节文字

三、通过原生函数截取

将下面的代码添加到主题的 functions.php 文件:

  1. function customTitle($limit) {
  2.     $title = get_the_title($post->ID);
  3.     if(strlen($title) > $limit) {
  4.         $title = substr($title, 0, $limit) . '...';
  5.     }
  6.  
  7.     echo $title;
  8. }

然后在输出文章标题的地方,使用下面的代码:

  1. <?php customTitle(30); ?>

注:30为标题字数,请根据自己的需求修改。如果标题字数小于30,就显示完整标题;如果字数大于30,就截取30个字符,末尾自定添加…

四、通过CSS来“截取”

严格来说,这不是截取,而是隐藏了溢出的字符。对标题所在的选择器 id 或 class 添加下面的样式:

  1. .post-title{
  2.  display:block;/*内联对象需加*/ 
  3.  width:31em; /* 限制宽度*/
  4.  word-break:keep-all;/* 不换行 */ 
  5.  white-space:nowrap;/* 不换行 */ 
  6.  overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */ 
  7.  text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一起使用。*/  
  8. }

五、自定义函数

将下面的代码添加到主题的 functions.php 文件:

  1. function cut_str($sourcestr,$cutlength){
  2. $returnstr='';
  3. $i=0;
  4. $n=0;
  5. $str_length=strlen($sourcestr);//字符串的字节数
  6. while (($n<$cutlength) and ($i<=$str_length)){
  7. $temp_str=substr($sourcestr,$i,1);
  8. $ascnum=Ord($temp_str);//得到字符串中第$i位字符的ascii码
  9. if ($ascnum>=224)    //如果ASCII位高与224,
  10. {
  11. $returnstr=$returnstr.substr($sourcestr,$i,3); //根据UTF-8编码规范,将3个连续的字符计为单个字符
  12. $i=$i+3;            //实际Byte计为3
  13. $n++;            //字串长度计1
  14. }
  15. elseif ($ascnum>=192) //如果ASCII位高与192,
  16. {
  17. $returnstr=$returnstr.substr($sourcestr,$i,2); //根据UTF-8编码规范,将2个连续的字符计为单个字符
  18. $i=$i+2;            //实际Byte计为2
  19. $n++;            //字串长度计1
  20. }
  21. elseif ($ascnum>=65 && $ascnum<=90) //如果是大写字母,
  22. {
  23. $returnstr=$returnstr.substr($sourcestr,$i,1);
  24. $i=$i+1;            //实际的Byte数仍计1个
  25. $n++;            //但考虑整体美观,大写字母计成一个高位字符
  26. }
  27. else                //其他情况下,包括小写字母和半角标点符号,
  28. {
  29. $returnstr=$returnstr.substr($sourcestr,$i,1);
  30. $i=$i+1;            //实际的Byte数计1个
  31. $n=$n+0.5;        //小写字母和半角标点等与半个高位字符宽…
  32. }
  33. }
  34. if ($str_length>$cutlength){
  35. $returnstr = $returnstr . "…";//超过长度时在尾处加上省略号
  36. }
  37. return $returnstr;
  38. }

调用自定义函数cut_str()

  1. <?php echo cut_str($post->post_title,30); ?>

小结

1、wp_trim_words函数会把一个汉字当做一个字符,当标题里有字母有汉字时不适合做标题。

2、强烈推荐PHP原生截断函数mb_strimwidth。


发布日期:

所属分类: Wordpress 综合 标签: