0

0

如何使用 WordPress Hook 显示待审帖子

花韻仙語

花韻仙語

发布时间:2025-09-19 20:53:01

|

204人浏览过

|

来源于php中文网

原创

如何使用 wordpress hook 显示待审帖子

本文旨在指导 WordPress 开发者如何修改默认的最新文章模块,使其显示待审(pending)状态的文章,而非已发布(publish)的文章。我们将通过 pre_get_posts 钩子,修改文章查询参数,实现只针对特定页面和具有特定权限的用户显示待审文章的目的。本文将提供详细的代码示例和注意事项,帮助开发者安全有效地完成修改。

修改 WordPress 最新文章模块显示待审文章

WordPress 默认的最新文章模块通常显示已发布的文章。然而,在某些情况下,例如网站管理员需要审核待发布的文章时,需要显示待审状态的文章。本文将介绍如何使用 WordPress 的 pre_get_posts 钩子来实现这一功能。

pre_get_posts 钩子允许我们在 WordPress 执行文章查询之前修改查询参数。这使得我们可以根据特定条件改变查询的行为,例如改变文章状态、文章类型、排序方式等。

代码实现

以下代码展示了如何使用 pre_get_posts 钩子来修改文章查询,使其显示待审文章:

Autoppt
Autoppt

Autoppt:打造高效与精美PPT的AI工具

下载
function show_pending_posts( $query ) {
    // 避免影响后台和主查询
    if ( is_admin() || ! $query->is_main_query() ) {
        return;
    }

    // 仅在特定页面且用户具有发布权限时修改查询
    if( get_query_var('pagename') == 'name_of_the_page' && current_user_can('publish_posts') ) {
        $query->set( 'post_status', 'pending' );
    }
}
add_action( 'pre_get_posts', 'show_pending_posts' );

代码解释:

  1. show_pending_posts( $query ): 定义一个函数,该函数接收 $query 对象作为参数。$query 对象包含了 WordPress 即将执行的查询的所有参数。
  2. is_admin() || ! $query->is_main_query(): 这是一个重要的检查。is_admin() 确保我们不会在 WordPress 后台修改查询,因为这可能会影响后台的功能。! $query->is_main_query() 确保我们只修改主查询,避免影响其他自定义查询。
  3. get_query_var('pagename') == 'name_of_the_page' && current_user_can('publish_posts'): 这是一个条件判断。get_query_var('pagename') 获取当前页面的名称,我们将其与 'name_of_the_page' 进行比较,以确保我们只在特定页面上修改查询。current_user_can('publish_posts') 检查当前用户是否具有发布文章的权限。这确保只有具有相应权限的用户才能看到待审文章。 注意:将 name_of_the_page 替换为你的实际页面名称。
  4. $query->set( 'post_status', 'pending' ): 这是修改查询的关键部分。$query->set() 方法允许我们修改查询参数。在这里,我们将 post_status 参数设置为 'pending',这意味着查询将只返回待审状态的文章。
  5. add_action( 'pre_get_posts', 'show_pending_posts' ): 这行代码将 show_pending_posts 函数挂载到 pre_get_posts 钩子上。这意味着在 WordPress 执行任何文章查询之前,show_pending_posts 函数都会被调用。

如何使用

  1. 将上述代码添加到你的 WordPress 主题的 functions.php 文件中,或者添加到自定义插件中。
  2. 将代码中的 'name_of_the_page' 替换为你希望显示待审文章的页面的实际名称。
  3. 确保当前用户具有 publish_posts 权限,或者根据你的需求修改权限检查。

注意事项

  • 缓存问题: 修改查询参数后,可能需要清除 WordPress 缓存或服务器缓存,以确保更改生效。
  • 插件冲突: 某些插件可能会修改文章查询,导致你的代码无法正常工作。如果遇到问题,尝试禁用其他插件,看看是否解决了问题。
  • 安全性: 确保只允许具有适当权限的用户查看待审文章,以避免安全问题。
  • 代码位置: 建议将代码放置在子主题的 functions.php 文件中,避免主题更新导致代码丢失。

总结

通过使用 pre_get_posts 钩子,我们可以灵活地修改 WordPress 的文章查询,从而实现各种自定义需求。本文提供了一个具体的示例,展示了如何修改查询以显示待审文章。记住,在修改查询参数时,务必小心谨慎,避免影响网站的其他功能。始终进行充分的测试,以确保你的代码按预期工作。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2644

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1656

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1513

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

952

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1418

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1234

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1448

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1306

2023.11.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

68

2026.01.16

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 8.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 7.9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号