当前位置: 首页 > 设计 > 正文
avatar

关于WordPress的首页文章摘要,首先显示摘要,如果没有摘要的则显示用more标签截断的,如果没有more标签则显示文章截取多少字的,如果主机不支持mb_strimwidth函数截断,则才显示全文。

关于WordPress的首页文章摘要,我想很多人都有自己不同的看法,关注我博客的或者使用我主题我想大家都知道,我使用的是截取文章的部分(大约350字)来作为摘要的。

其实我个人并不是很喜欢这种摘要的显示方式,但是这个方法用起来比较方便而已。

WordPress是有摘要功能的,写文章的时候填写一些摘要是一个很好的习惯,我主题设置摘要给搜索引擎看的。

不过并不是很多人在发表文章的时候填写这个摘要,所以我也一直纠结是否在主题设计的时候首选使用摘要模式。

网上使用摘要的代码大多是这样的

<?php if(!is_single()) {
     the_excerpt();
 } else {
     the_content(__('(more...)'));
 } ?>

首选显示摘要,如果没有摘要则显示全部文章,话说显示全部文章肯定是不给力的,万一一篇文章很长怎么办,首页能放几篇文章?

今天看到一篇很好的文章,解决了这一问题,文章想到了我所想要的,非常不错。较完美的WordPress文章摘要(截断)方案,目前已无法打开。

首先显示摘要,如果没有摘要的则显示用more标签截断的,如果没有more标签则显示文章截取多少字的,如果主机不支持mb_strimwidth函数截断,则才显示全文。

大家觉得这种显示方法怎么样,如果大家觉得OK,我新版的主题将使用这个作为首页文章摘要了。

<?php //这是为了在单篇文章(或页面)直接显示全部内容,而不使用以下的判断
    if(is_singular()){the_content();}else{
    //定义两个$
    $pc=$post->post_content;
    $st=strip_tags(apply_filters('the_content',$pc));
    //判断是否存在 内置摘要
    if(has_excerpt())
        the_excerpt();
    /*使用正则表达式尝试匹配more标签,
    并判断如果存在more标签, 或者正文内容长度小于300, 则直接以more标签方式显示,
    即是说, 有more便显示more, 没more且长度小于300则直接显示全文.
    我使用了mb_strwidth来判断长度.
    */
    elseif(preg_match('/<!--more.*?-->/',$pc) || mb_strwidth($st)<300)
        the_content('Read more &raquo;');
    //否则...以下
    elseif(function_exists('mb_strimwidth'))//判断是否支持mb_strimwidth函数
        echo'<p>'//mb_strimwidth截断后得到的是纯文本, 所以我给它包了一层 p
        .mb_strimwidth($st,0,300,' ...')//对文本内容截断, 从位置0开始往后截取300长度, 超出部分以点点点替代
        .'</p><p class="read-more"><a title="'//给截断的内容添加一个与 STEP 1 完全一模一样的"more标签"...
        .the_title("继续阅读: ","",false)//注意这里与 STEP 1 相比, 使用了另一个函数来获取标题
        .'" rel="nofollow" href="'
        .post_permalink()
        .'" class="more-link">Read more &raquo;</a></p>';
    else the_content();//最后没有选择的选择...
}?>
本文固定链接: http://www.weisay.com/blog/wordpress-article-excerpt.html | 威言威语

WordPress文章摘要多种展示方案:目前有94 条评论

  1. avatar
    40楼
    90后博客 Google Chrome Windows

    如果是诗歌形式的文章,分行太多,好像摘要很不协调,这个要怎么去解决,显示摘要的时候能不能过滤掉回车?。其他普通文章显示很棒。

    2016-07-26 09:40 [回复]
    • avatar
      William Mozilla Firefox Windows

      诗歌的话还是建议自己手动添加一下文章的摘要。

      2016-08-17 15:24 [回复]
  2. avatar
    39楼
    多盈网 UC浏览器 Windows

    有不有办法让首页置顶的文章显示全文 其它的显示摘要?求助

    2016-05-24 23:48 [回复]
    • avatar
      William Mozilla Firefox Windows

      已经将修改的文件通过你评论留言的邮箱发送给你了,请注意查收。

      2016-05-25 11:19 [回复]
      • 非常感谢William ,已收到您的邮箱,问题已解决,感激不尽!

        2016-05-25 19:58 [回复]
  3. avatar
    38楼
    94楼 Google Chrome Windows

    站长 怎么关掉摘要呢 首页有摘要 会有很多图片 网站打开速度很慢

    2014-07-12 17:17 [回复]
    • avatar
      William Mozilla Firefox Windows

      发布文章的时候记得填写文章摘要,这是最好的方式。这样你填写的文字就会显示在首页了。

      2014-07-15 19:46 [回复]
  4. avatar
    37楼
    阿城守候 Mozilla Firefox Windows

    用上了,謝謝分享

    2013-04-28 04:46 [回复]
  5. avatar
    36楼
    KO Google Chrome Windows

    很好!

    2013-03-08 14:06 [回复]
  6. avatar
    35楼
    xilouqingzhu Google Chrome Windows

    Weisay Simple这个主题用了文章中的摘要代码么,为什么我手动写了摘要,还是用自动截取的摘要

    2012-08-16 09:19 [回复]
  7. avatar
    34楼
    卿卿 Google Chrome Windows

    不知道怎么替换的我很想把摘要弄成原来默认的,我宁愿自己花时间写摘要,也不要他自己判断,真心不好用。

    2012-05-02 21:34 [回复]
    • avatar
      William Google Chrome Windows

      替换原主题中那段截取代码就行了,真心不难 :shock:

      2012-06-04 10:39 [回复]
  8. avatar
    33楼
    stone060 Google Chrome Windows

    我想知道文摘截断的功能要怎样去掉!我愿意自己写文摘!那个自动获取的不是很爽。

    2012-04-30 15:05 [回复]
    • avatar
      William Google Chrome Windows

      你可以用上面的代码去替换原来主题的摘要部分,就能用自己写的摘要了。

      2012-05-02 17:02 [回复]
  9. avatar
    32楼
    Noisy Guy Safari Mac OS

    我改了一下,发现很难看的,有摘要的还好,没摘要的时候真的是丑死了,还多出一个Read More出来,而且如果有图的话还会显示图片,总之就是风格全变了

    2012-04-30 04:01 [回复]
    • 我又改了一下,把more标签的判断去掉,就只要判断摘要和300个字符截断就好了,这样好看点

      2012-04-30 04:33 [回复]
      • avatar
        William Google Chrome Windows

        上面写法算是比较全面了,各个人有自己的喜好,然后自己根据自己的喜好修改成符合自己的就最好了。 :cool:

        2012-05-02 17:04 [回复]
  10. avatar
    31楼
    唐文博客 360安全浏览器 Windows

    我用的威哥这主题,还不错

    2012-03-27 16:57 [回复]

发表评论

question razz sad smile redface biggrin surprised eek confused cool lol mad rolleyes wink neutral cry

快捷键:Ctrl+Enter