0

0

获取自定义文章类型分类描述的教程

霞舞

霞舞

发布时间:2025-12-02 13:15:13

|

884人浏览过

|

来源于php中文网

原创

获取自定义文章类型分类描述的教程

本教程详细介绍了如何在wordpress中,当对自定义文章类型进行分类筛选时,显示对应分类(taxonomy)的描述信息。通过先遍历分类术语,然后针对每个术语执行文章查询,可以实现将分类名称和描述与相关文章内容一同一同展示,从而构建结构化且信息丰富的页面布局。

在WordPress开发中,我们经常需要创建自定义文章类型(Custom Post Types, CPT)并为其定义自定义分类法(Custom Taxonomies),例如为“作品集”(Portfolio)文章类型创建“作品分类”(Portfolio Category)。当用户浏览或筛选这些作品时,通常希望在展示作品列表的同时,也能看到当前所选分类的详细描述。本文将指导您如何实现这一功能,通过组织查询逻辑,确保分类描述能与其关联的文章内容一同呈现。

核心思路

实现这一功能的关键在于改变传统的文章查询方式。通常我们直接查询文章,然后获取其分类信息。但为了在文章列表之前或之上显示分类描述,我们需要反向操作:首先遍历所有目标分类术语(terms),然后针对每个术语,执行一次独立的文章查询,以获取属于该术语的所有文章。这样,在每次术语循环中,我们都可以先输出术语的名称和描述,再输出其下的文章。

逐步实现

以下是实现此功能的具体步骤和代码示例:

1. 获取所有目标分类术语

首先,我们需要使用 get_terms() 函数来获取特定自定义分类法下的所有术语。

 false // 如果需要显示没有文章的分类,设置为 false
));

// 检查是否成功获取到术语且没有WordPress错误
if (!is_wp_error($terms) && !empty($terms)) :
    // 后续操作将在该循环内部进行
endif;
?>

2. 遍历每个分类术语

获取到术语列表后,我们需要遍历它们。在每次循环中,当前 $term 对象将包含该分类术语的所有信息,包括名称 ($term->name) 和描述 ($term->description)。


        

name); ?>

description)) : ?>

description); ?>

3. 为每个术语执行文章查询

在每次术语循环内部,我们将创建一个新的 WP_Query 实例,专门查询属于当前 $term 的文章。这需要使用 tax_query 参数。


            
'YOUR_CUSTOM_POST_TYPE', // 替换为您的自定义文章类型,例如 'portfolio' 'post_status' => 'publish', 'posts_per_page' => -1, // 显示所有文章,或指定数量 'tax_query' => [ [ 'taxonomy' => 'portfolio_category', // 替换为您的自定义分类法 'field' => 'term_id', 'terms' => $term->term_id // 根据当前循环的术语ID进行筛选 ] ] ]; $query = new WP_Query($args); if ($query->have_posts()) : while ($query->have_posts()) : $query->the_post(); // 在这里输出每篇文章的内容 ?>

此分类下暂无文章。

'; endif; ?>

完整代码示例

将以上片段整合,您将得到一个功能完整的代码块,用于在WordPress页面模板中显示按分类组织的自定义文章类型,并包含分类描述:

 false // 如果需要显示没有文章的分类,请设置为 false
));

// 检查是否成功获取到术语且没有WordPress错误
if (!is_wp_error($terms) && !empty($terms)) :
    foreach ($terms as $term) :
?>
        

name); ?>

description)) : ?>

description); ?>

'portfolio', // 您的自定义文章类型 'post_status' => 'publish', 'posts_per_page' => -1, // 显示所有文章 'tax_query' => [ [ 'taxonomy' => 'portfolio_category', // 您的自定义分类法 'field' => 'term_id', 'terms' => $term->term_id // 根据当前术语ID筛选 ] ] ]; $query = new WP_Query($args); if ($query->have_posts()) : while ($query->have_posts()) : $query->the_post(); // 输出每篇文章的HTML结构 ?>

此分类下暂无相关作品。

'; endif; ?>
未找到任何作品分类。

'; endif; ?>

注意事项与最佳实践

  1. 替换占位符: 务必将代码中的 YOUR_CUSTOM_POST_TYPE 和 portfolio_category 替换为您实际使用的自定义文章类型和自定义分类法名称。
  2. wp_reset_postdata(): 在每次 WP_Query 循环结束后,调用 wp_reset_postdata() 至关重要。它会重置全局的 $post 数据,确保后续的WordPress循环(例如主查询或页面上的其他查询)不会受到当前自定义查询的影响。
  3. 错误处理: 使用 !is_wp_error($terms) 检查 get_terms() 是否返回了错误,增强代码的健壮性。
  4. hide_empty 参数: get_terms() 函数的 hide_empty 参数决定是否显示没有关联文章的分类。根据您的需求设置为 true (默认) 或 false。
  5. 性能考虑: posts_per_page => -1 会获取所有匹配的文章。如果某个分类下的文章数量非常大,这可能会影响页面加载性能。对于大量文章的分类,您可能需要考虑分页或限制显示数量。
  6. HTML 结构: 示例代码提供了基本的 HTML 结构,您可以根据自己的前端设计和 CSS 框架(如 Bootstrap)进行调整和美化。
  7. 可访问性: 确保您的 HTML 结构和内容符合可访问性标准。

总结

通过上述方法,您可以有效地在WordPress中展示按自定义分类法组织的自定义文章类型,并为每个分类提供详细的描述。这种结构化的内容展示方式不仅提升了用户体验,也使得页面内容更具信息量和可读性,特别适用于作品集、产品目录或知识库等场景。理解并应用这种“先分类后文章”的查询逻辑,是WordPress高级开发中一项非常实用的技能。

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

263

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

754

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

760

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

605

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

560

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

395

2023.08.22

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

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

43

2026.01.16

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.9万人学习

CSS教程
CSS教程

共754课时 | 20.2万人学习

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

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