当前所在位置: 首页>>百科全书

给WordPress旧文章增加自定义提示内容

发布时间:2025-10-23 09:47:01 本站作者 【 字体: 】 浏览:9 次

在这个信息爆炸的时代,我们缺的不是大量的信息,而是准确有效的信息。可能我们前两年写得文章内容已经跟现在的情况不太符合了,特别是一些教程攻略,可能随着软件、数据的更新不再准确。那么我可以对长期未更新的旧文章做一个提示,告诉读者这篇文章已经长期未更新,请注意文章准确性。

《给WordPress旧文章增加自定义提示内容》

如下图所示,本站对超过一定时间未更新的旧文章增加了提示功能,在文尾会出现如下提示框,也算是对读者负责任吧,下面分享具体方法。

《给WordPress旧文章增加自定义提示内容》

其实非常简单,只需要在function.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');

如果你想该提示框出现在文章的开头,则需要将代码改下(将$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');

提供一个模板样式,大家可以根据自己需要进行修改(使用此样式的朋友请自行上传CSS中的小图标)上传到你主题文件中style.css

/* 提醒 */ .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函数延伸

本功能使用了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)) ){

本站的修改为:

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

增加了判断is_single()是否为文章页,CSS部分:

/* 旧文章更新提醒 */.old-post-two-year{
 color: #ad9948;
 background: #fff4b9 url(/images/warn.png) -1px -1px no-repeat;
 border: 1px solid #eac946;
 overflow: hidden;
 margin: 8px 0;
 padding: 10px 10px 10px 35px;
 font-size: 14px;
 }
.old-post-half-year{
 color: #BEBEBE;
 overflow: hidden;
 margin: 8px 0;
 padding: 10px 10px 10px 10px;
 font-size: 14px;
 }
.old-post-zero-year{
 color: #BEBEBE;
 overflow: hidden;
 margin: 8px 0;
 padding: 10px 10px 10px 5px;
 font-size: 14px;
 }
}


上一篇:WordPress回复已有评论自动添加“@原评论者昵称”

下一篇:WordPress小工具在指定页面显示的插件:AH Display Widgets

广告位-300PX*250PX
最新发布
WordPress取消英文标点符号自动替换中文标点符号的优雅方法

WordPress取消英文标点符号自动替换中文标点符号的优雅方法

WordPress取消英文标点符号自动替换中文标点符号的优雅方法
众所周知,WordPress中文版有个特性,会将每一处英文引号("")都稀里哗啦转化为中文引号(“”)。不仅仅是英文引号,在WordPress翻译文件定义了不少自动转换符号,具体可以参考这里。对文字博客来说,这是个好功能,这样会避免用错英文标点。然而,WordPress是独立的php程序,中文社区中懂得使用者,大部分都是...
如何手动将本地WordPress站点迁移到主机/服务器?

如何手动将本地WordPress站点迁移到主机/服务器?

如何手动将本地WordPress站点迁移到主机/服务器?
在自己电脑上搭建一个本地环境来建立和完善站点是很有必要的,比如Windows系统可以安装 WAMP 或phpStudy,Mac 系统可以安装 MAMP 软件。至于如何安装这里就不展开说了,下面我们说一下如何手动将本地完善好的 WordPress 站点迁移到主机/服务器中。1、导出本地 WordPress 数据库利用phpMyAdmin来导出本地 WordPress 站...
利用WordPress移动设备判断函数wp_is_mobile()进行差异化的广告投放

利用WordPress移动设备判断函数wp_is_mobile()进行差异化的广告投放

利用WordPress移动设备判断函数wp_is_mobile()进行差异化的广告投放
在去年9月份本站通过了谷歌广告联盟的审核,诸位也可以看到,本站部分区有添加一些个广告。在部署这些广告的时候,其中有一个叫“自动广告”的新鲜家伙,即它最大特点是只需要部署一段代码就可完成全站的广告投放,至于广告在哪里显示?显示什么类型广告?如何与站点内容匹配?这些统统无需本屌关注,都交给联盟智能判断处理...
两行代码禁用 WordPress 5.0 的 Gutenberg(古腾堡) 编辑器

两行代码禁用 WordPress 5.0 的 Gutenberg(古腾堡) 编辑器

两行代码禁用 WordPress 5.0 的 Gutenberg(古腾堡) 编辑器
WordPress 更新到 5.0 版本后,程序内置并强制启用了新的新的Gutenberg 编辑器(在WP5.0中准确地说应该叫block editor编辑器),据说编辑功能更加强大高效,但是我的需求就是写几行文字加几张图片,新编辑器灰常的不友好,不习惯..当然我们可以使用“Classic Editor”插件让熟悉的经典编辑器回来。但是像目前完全不想用Gute...