让代码更简单

当前位置:代码狗 > WordPress > WP建站 > 正文

WordPress添加文章过时失效提示

重要:本文最后更新于2019-11-30 13:47:09,某些文章具有时效性,若有错误或已失效,请在下方留言或联系代码狗

不知不觉已经使用WP建站3年多了,最近两年基本保持每天一篇文章的频率更新,但部分文章具有时效性,比如活动,比如某些工具等。这类文章不仅无法帮助找到这篇文章的人,反而会误导他们,白白浪费时间与精力。前段时间帮某缙写了这段代码,于是拿来套用之。

实现原理

输出WordPress数据库中存储的文章最后更新时间字段,并与访问者访问时间对比,如果访问时间大于最后更新时间+一天,则输出文章失效提示,反之则不输出。这里的1天可以自行定义。为了方便大家使用,我这里提供了两种方式,自行选择。

钩子函数挂载

利用WordPress提供的the_content()钩子挂载。当然,这样会导致所有页面中及摘要中都会出现提示。不建议使用此方法

functions.php文件中加入如下代码

//文章过期提示
function article_time_update($content) {
    date_default_timezone_set('PRC');
    $newdate=time();
    $updated_date = get_the_modified_time('Y-m-d H:i:s');
    $updatetime=strtotime($updated_date);
    $custom_content = '';
    if ( $newdate > $updatetime+86400) {
    $custom_content= '<div class="article-timeout"><strong>重要:</strong>本文最后更新于<code>'. $updated_date . '</code>,某些文章具有时效性,若有错误或已失效,请在下方<a href="#comment">留言</a>或联系<a target="_blank" title="代码狗博客" href="https://www.daimadog.com/about"><b>代码狗</b></a>。</div >';
    }
        echo $custom_content.$content;
    }
add_action('the_content','article_time_update');

不建议使用此方法,因为部分主题可能会在摘要部分显示提示信息!

直接调用函数

如果你只需要文章提示,那么可以直接修改下你的文章模板single.php,在the_content()函数之前调用下如下函数。

先将下面的函数代码加入到你的functions.php文件中。

//文章过期提示
function article_time_update() {
    date_default_timezone_set('PRC');
    $newdate=time();
    $updated_date = get_the_modified_time('Y-m-d H:i:s');
    $updatetime=strtotime($updated_date);
    $custom_content = '';
    if ( $newdate > $updatetime+86400) {
    $custom_content= '<div class="article-timeout"><strong>重要:</strong>本文最后更新于<code>'. $updated_date . '</code>,某些文章具有时效性,若有错误或已失效,请在下方<a href="#comment">留言</a>或联系<a target="_blank" title="代码狗博客" href="https://www.daimadog.com/about"><b>代码狗</b></a>。</div >';
    }
        echo $custom_content;
    }

single.php文件中找到the_content()函数,并在其之前加上article_time_update()即可。

具体效果如本站文章页面,下面是我的css

.article-timeout {
  position: relative;
  color: #999;
  margin-bottom: 25px;
  padding: 15px;
  background-color: #fbfbfb;
  border-top: 1px solid #f0f0f0;
  border-bottom: 1px solid #f0f0f0;
}

感觉很棒!可以赞赏支持我哟~

赞(0) 打赏

评论 2

  1. #2

    我就去试试有没有这么牛逼,有的话我给你留个外链,帮你引个流。

  2. #1

    学习了!

    缙哥哥2周前 (11-29)回复
×

请作者吃根烤肠!

支付宝