0

0

WordPress 前端页面显示所有分类及获取分类详情的实用指南

花韻仙語

花韻仙語

发布时间:2025-08-07 23:22:16

|

562人浏览过

|

来源于php中文网

原创

WordPress 前端页面显示所有分类及获取分类详情的实用指南

本教程详细介绍了如何在WordPress的front-page.php文件或任何模板中,有效显示所有分类(包括空分类)并获取其详细信息。文章重点讲解了wp_list_categories()和get_categories()这两个核心函数的应用,特别是如何通过hide_empty=0参数解决默认不显示空分类的问题,并提供了获取分类ID、名称和链接的实用代码示例,帮助开发者灵活定制分类显示方式。

wordpress主题开发中,我们经常需要在自定义模板文件(如front-page.php、page.php或任何其他自定义页面模板)中展示网站的所有分类。然而,开发者有时会遇到wp_list_categories()等函数无法显示所有分类,特别是那些当前没有关联文章的空分类的问题。本教程将深入探讨如何解决这一常见挑战,并提供两种主要方法来灵活地获取并展示wordpress分类信息,包括如何获取分类的term_id以便进一步定制。

方法一:使用 wp_list_categories() 显示所有分类

wp_list_categories() 是WordPress提供的一个便捷函数,用于生成分类列表。它的默认行为是为了优化性能和用户体验,通常会隐藏那些没有任何文章的空分类。如果你发现它只返回“未分类”等少数分类,很可能是因为其他分类下没有文章,或者你没有设置正确的参数。

要强制 wp_list_categories() 显示所有分类,包括空分类,你需要设置 hide_empty 参数为 0(或 false)。

示例代码:

这段代码将生成一个无序列表(

    )形式的所有分类链接,即使这些分类目前没有关联任何文章。

    立即学习前端免费学习笔记(深入)”;

    注意事项:

    • wp_list_categories() 提供了丰富的参数,可以控制输出的格式、排序、是否显示文章计数等。例如,title_li 参数可以移除默认的“分类”标题。
    • 虽然它方便快捷,但如果你需要对每个分类的输出进行高度定制(例如,添加自定义图片、额外的HTML结构),wp_list_categories() 的灵活性可能不足。

    方法二:使用 get_categories() 进行更灵活的分类查询和展示

    对于需要更精细控制分类输出的场景,get_categories() 函数是更强大的选择。它返回一个分类对象数组,你可以遍历这个数组,并为每个分类构建自定义的HTML结构。

    Videoleap
    Videoleap

    Videoleap是一个一体化的视频编辑平台

    下载

    与 wp_list_categories() 类似,get_categories() 也有一个 hide_empty 参数,默认值为 true。要获取所有分类,包括空分类,你需要将其设置为 0 或 false。

    示例代码:

     0, // 确保显示所有分类,包括空分类
        'orderby'    => 'name', // 按名称排序
        'order'      => 'ASC'   // 升序排列
    ) );
    
    if ( ! empty( $categories ) ) {
        echo '

    所有网站分类

    '; echo '
      '; foreach( $categories as $category ) { // 获取分类链接 $category_link = get_category_link( $category->term_id ); // 获取分类名称 $category_name = $category->name; // 获取分类描述 $category_description = $category->description; // 获取分类ID,这对于获取自定义元数据(如自定义图片)非常有用 $category_id = $category->term_id; // 示例:输出分类链接、名称,并可以根据需要添加自定义图片 echo '
    • '; echo ''; echo esc_html( $category_name ); echo ''; // 假设你为分类上传了自定义图片,并将其存储为分类的元数据 // 你可以使用 get_term_meta() 函数来获取它 // 例如:$custom_image_url = get_term_meta( $category_id, 'category_custom_image', true ); // if ( $custom_image_url ) { // echo '@@##@@'; // } if ( ! empty( $category_description ) ) { echo '

      ' . esc_html( $category_description ) . '

      '; } echo '
    • '; } echo '
    '; } else { echo '

    暂无可用分类。

    '; } ?>

    代码解析:

  1. get_categories( array( 'hide_empty' => 0 ) ):获取所有分类对象,并存储在 $categories 数组中。
  2. foreach( $categories as $category ):遍历每个分类对象。
  3. $category->term_id:获取当前分类的ID。这是非常重要的,因为它是获取分类链接、以及任何自定义元数据(如自定义图片URL)的关键。
  4. get_category_link( $category->term_id ):根据分类ID获取分类的URL。
  5. $category->name:获取分类的名称。
  6. $category->description:获取分类的描述。
  7. esc_url() 和 esc_html():这些是WordPress的转义函数,用于确保输出内容的安全性,防止XSS攻击。在输出任何来自数据库或用户输入的内容时,都应该使用适当的转义函数。
  8. 获取自定义图片: 原始问题中提到为每个分类上传了自定义图片。WordPress本身没有内置的分类图片功能,但这通常通过插件(如 Advanced Custom Fields, CMB2)或自定义代码实现,将图片URL作为分类的元数据存储。一旦你有了 term_id,你就可以使用 get_term_meta( $category_id, 'your_meta_key', true ) 来检索这些自定义数据。

总结

无论是使用 wp_list_categories() 还是 get_categories(),关键在于理解 hide_empty 参数的作用,它是显示所有分类(包括空分类)的核心。对于快速生成标准列表,wp_list_categories() 是首选;而当需要对分类的显示进行高度定制,例如整合自定义图片、添加额外信息或构建复杂布局时,get_categories() 结合循环遍历的方式提供了更大的灵活性和控制力。始终记得在输出动态内容时使用WordPress的转义函数,以确保网站的安全性。

' . esc_attr( $category_name ) . '

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

76

2025.12.04

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

360

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2083

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

349

2023.08.31

MySQL恢复数据库
MySQL恢复数据库

MySQL恢复数据库的方法有使用物理备份恢复、使用逻辑备份恢复、使用二进制日志恢复和使用数据库复制进行恢复等。本专题为大家提供MySQL数据库相关的文章、下载、课程内容,供大家免费下载体验。

256

2023.09.05

vb中怎么连接access数据库
vb中怎么连接access数据库

vb中连接access数据库的步骤包括引用必要的命名空间、创建连接字符串、创建连接对象、打开连接、执行SQL语句和关闭连接。本专题为大家提供连接access数据库相关的文章、下载、课程内容,供大家免费下载体验。

326

2023.10.09

数据库对象名无效怎么解决
数据库对象名无效怎么解决

数据库对象名无效解决办法:1、检查使用的对象名是否正确,确保没有拼写错误;2、检查数据库中是否已存在具有相同名称的对象,如果是,请更改对象名为一个不同的名称,然后重新创建;3、确保在连接数据库时使用了正确的用户名、密码和数据库名称;4、尝试重启数据库服务,然后再次尝试创建或使用对象;5、尝试更新驱动程序,然后再次尝试创建或使用对象。

413

2023.10.16

vb连接access数据库的方法
vb连接access数据库的方法

vb连接access数据库方法:1、使用ADO连接,首先导入System.Data.OleDb模块,然后定义一个连接字符串,接着创建一个OleDbConnection对象并使用Open() 方法打开连接;2、使用DAO连接,首先导入 Microsoft.Jet.OLEDB模块,然后定义一个连接字符串,接着创建一个JetConnection对象并使用Open()方法打开连接即可。

411

2023.10.16

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十三期_前端开发
第二十三期_前端开发

共98课时 | 7.6万人学习

WordPress视频教程
WordPress视频教程

共23课时 | 9.7万人学习

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

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