WordPress真正的自动截取日志内容

林继 WordPress 3,379 共写了609个字 (2011-01-02 12:30:20) 没有评论 打印 扫描二维码 百度已收录

WordPress在不使用任何的插件的情况下是能在首页截取内容,但她实现起来不是那么方便,或要自己做文章的中间加;或要修改主题中的标签。总之是不太方便吧。要怎样才能让WordPress真正的自动实现在首页截取内容(除了单篇文章的其他页面)只显示指定字节数的摘要,而不用操作其他不关文章的事呢?今天找到了下面的代码希望可以帮你实现。
以下代码作者 冰古

  1. /**
  2.  * author 冰古
  3.  * link http://wanwp.com
  4.  */
  5. $size = 500;    // 500是显示的字节数,可按照自己的要求修改
  6. $more_link_text = 'more...';    // 显示在摘要后面的提示
  7.  
  8. add_action('the_content', 'control_content_size');
  9.  
  10. function control_content_size($content) {
  11.     global $size, $more_link_text;
  12.     if (is_singular()) return $content;
  13.     $content = strip_tags($content);
  14.     $content = cut_str($content, $size);
  15.     $content = '<p>' . $content . '</p><p><a href="' . get_permalink() . "\" class=\"more-link\">$more_link_text</a></p>";
  16.     return $content;
  17. }
  18.  
  19. /**
  20.  * cut_str用于截断包含中文(或其他多字节?)的utf8编码的字符串
  21.  * @param string $str utf8编码的字符串
  22.  * @param int $len 需要截取的长度(单位是字节)
  23.  */
  24. function cut_str($str, $len) {
  25.     if (!isset($str[$len])) {
  26.         // 判断字符串长度是否已经达到需要截取的长度
  27.         // 未达到时,直接输出原字符串
  28.     } else {
  29.         if (seems_utf8($str[$len-1])) // 判断截断字符串的最后一个字符是否是utf8编码的
  30.             $str = substr($str, 0, $len); // 如果是utf8编码的,直接截断输出
  31.         else { // 如果不是utf8编码的,因为utf8编码的中文是三个字节进行保存的,则判断该字符和周围字符组成的字符串是否符合utf8编码
  32.             if(seems_utf8($str[$len-3].$str[$len-2].$str[$len-1]))
  33.                 $str = substr($str, 0, $len-3) . $str[$len-3] . $str[$len-2] . $str[$len-1];
  34.  
  35.             elseif(seems_utf8($str[$len-2].$str[$len-1].$str[$len]))
  36.                 $str = substr($str, 0, $len-2) . $str[$len-2].$str[$len-1].$str[$len];
  37.  
  38.             elseif(seems_utf8($str[$len-1].$str[$len].$str[$len+1]))
  39.                 $str = substr($str, 0, $len-1) . $str[$len-1].$str[$len].$str[$len+1];
  40.  
  41.             else // 这个else应该不用也是可以的
  42.                 $str = substr($str, 0, $len);
  43.         }
  44.     }
  45.     return $str;
  46. }


代码的作用:
1. 首先判断是否在单篇文章页面(如果是,直接返回内容,下面的操作省略);
2. 然后把文章和WordPress自动添加的HTML标签过滤掉(如果不进行这步,可以想象页面将会大乱。);
3. 再然后截取内容的前面n个字节(这里使用了我之前写的WordPress可用的截断中文字符的函数);
4. 最后修饰一下,返回处理过的文章内容(怎样修饰,可以自己手动改改)。
使用方法:
1. 按照自己的要求修改代码中的$size和$more_link_text
2. 将修改后的代码加入到主题的functions.php中
或者automatic-excerpt插件到./wp-content/plugins文件夹中,然后在后台激活,当然不要忘了修改代码中的$size和$more_link_text啦。
提示:
1. 要在代码中修改显示的字节数和阅读全文的提示。
2. 如果你之前使用了,在显示中可能有点不好看。是因为这个原因没有激活这个插件。

历史上的今天

1月
2

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

发表评论

电子邮件地址不会被公开。 必填项已用*标注

< >