给 WordPress 的旧文章添加自定义提示

有时候我们的网站会发一些活动文章,软件下载什么的,随着时间活动可能会过期,这时候就需要一个提示,告诉读者这篇文章已经长期没有更新,可能活动已经过期 或者 下载已经失效等内容。

(旧文章提示)

下面教大家 给 WordPress 的旧文章添加自定义提示 方法:

1.「后台」→「外观」→「编辑」 「functions.php」文件,把以下的内容添加进去:

//添加老文章提示信息 
function old_content_message($content) {
$modified = get_the_modified_time('U');
$current = current_time('timestamp');
$diffTime = ($current - $modified) / (60 * 60 * 24);
if ($diffTime > 365) {
$content = $content.'<div class="warn">本文最后更新于'.get_the_modified_time('Y年n月j日').
',已超过 1 年没有更新,如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢!</div>';
}
return $content;
}
add_filter('the_content', 'old_content_message');

2.如果你想该提示框出现在文章的开头,则需要将代码改下(将$content放在提示后面)

//添加老文章提示信息
function old_content_message($content) {
$modified = get_the_modified_time('U');
$current = current_time('timestamp');
$diffTime = ($current - $modified) / (60 * 60 * 24);
if ($diffTime > 365) {
$content = '<div class="warn">本文最后更新于'.get_the_modified_time('Y年n月j日').
',已超过 1 年没有更新,如果文章内容或图片资源失效,请留言反馈,我们会及时处理,谢谢!</div>'.$content;
}
return $content;
}
add_filter('the_content', 'old_content_message');

 附带样式:

.warn {
color: #ad9948;
background: #fff4b9 url(img/warn.png) -1px -1px no-repeat;
border: 1px solid #eac946;
overflow: hidden;
margin: 10px 0;
padding: 15px 15px 15px 35px;
font-size: 14px;
}

 函数延伸介绍:

本功能使用了WordPress的get_the_modified_time函数,它可以获得文章的最后修改时间,包括你对内容、标签、置顶等信息的修改都会影响最后修改时间。第五行60*60*24是将计时单位(秒)转化成(天),第六行>365即最后修改时间大于一年的文章将会出现提示,你可以根据具体情况进行修改。

另外我们还可以控制哪些文章显示提醒,例如你只想让ID为8的分类中的文章显示提示信息,只需要将第六行代码添加判断条件即可,如下:

if($diffTime > 365 && in_category(8) ){

多个分类的话用数组形式添加,如让ID为8、9、10的分类文章显示提示信息,则修改第六行为

if($diffTime > 365 && in_category(array(8,9,10)) ){

同理如果想排除某些分类,除了这些分类的文章都显示提示信息,只需要在in_category前添加半角“!”既可,如不想让ID为8、9、10的分类文章显示提示信息,则修改第六行为

if($diffTime > 365 && !in_category(array(8,9,10)) ){

# 更多WordPress技巧,请关注「WordPress专题

方法代码参考:WordPress大学 | 本文来源:iyaxi