0

0

WordPress自定义文章类型分类(Taxonomy)的正确获取与查询方法

碧海醫心

碧海醫心

发布时间:2025-12-04 12:54:25

|

251人浏览过

|

来源于php中文网

原创

wordpress自定义文章类型分类(taxonomy)的正确获取与查询方法

本教程详细阐述了在WordPress中如何正确获取和显示自定义文章类型(Custom Post Type)的分类(Taxonomy)术语,以及如何根据这些术语查询相关文章。文章将纠正使用get_categories和cat参数的常见误区,并指导读者利用get_terms函数获取自定义分类术语,并通过WP_Query的tax_query参数实现精确的文章筛选,确保代码的专业性和效率。

在WordPress开发中,自定义文章类型(Custom Post Types, CPT)和自定义分类法(Custom Taxonomies)是扩展网站功能的强大工具。然而,许多开发者在处理自定义分类法时,常会混淆其与WordPress默认分类(Categories)的区别,导致在使用get_categories等函数时遇到问题。本教程将深入探讨如何正确地获取、显示自定义文章类型的分类术语,并根据这些术语查询相关文章。

理解WordPress分类法的基础

WordPress默认提供了两种内置分类法:category(分类)和post_tag(标签),它们主要用于管理默认文章类型post。当您创建自定义文章类型时,通常也需要为其注册自定义分类法,以便更好地组织内容。

例如,以下代码展示了如何在functions.php中为名为pdf的自定义文章类型注册一个名为pdf_cat的自定义分类法:

// 在 functions.php 中注册自定义分类法
function register_custom_pdf_taxonomy() {
    $args = array(
        'label'                 => 'PDF分类', // 分类法的显示名称
        'public'                => true,       // 是否公开可见
        'show_ui'               => true,       // 是否在后台显示管理界面
        'show_in_nav_menus'     => true,       // 是否在导航菜单中可用
        'show_admin_column'     => true,       // 是否在文章列表页显示为列
        'hierarchical'          => true,       // 是否具有层级结构(像分类一样)
        'query_var'             => true,       // 是否允许通过URL查询
        'rewrite'               => array( 'slug' => 'pdf-category' ), // URL重写规则
        'capabilities'          => array(
            'manage_terms'      => 'manage_categories',
            'edit_terms'        => 'edit_categories',
            'delete_terms'      => 'delete_categories',
            'assign_terms'      => 'assign_categories',
        ),
    );
    // 将 'pdf_cat' 分类法注册到 'pdf' 文章类型
    register_taxonomy('pdf_cat', 'pdf', $args);
}
add_action('init', 'register_custom_pdf_taxonomy');

上述代码注册了一个名为pdf_cat的分类法,并将其关联到自定义文章类型pdf。请注意,pdf_cat是一个独立的分类法,与WordPress默认的category分类法是不同的实体。

正确获取自定义分类法(Taxonomy)的术语(Terms)

当您需要获取特定自定义分类法下的所有术语(Terms),例如获取pdf_cat下的所有分类项时,不应使用get_categories()函数。get_categories()专门用于获取WordPress默认的category分类法下的分类。对于自定义分类法,正确的函数是get_terms()。

错误示例(应避免):

以下是尝试使用get_categories()来获取自定义文章类型pdf的分类的常见错误方式:

Mokker AI
Mokker AI

AI产品图添加背景

下载
<?php
// 这是一个错误示例,因为 get_categories() 不适用于自定义分类法
$args = array(
    'post_type' => 'pdf', // 尝试通过 post_type 过滤,但 get_categories() 不支持此参数
    'orderby'   => 'slug',
    'order'     => 'ASC',
    'parent'    => 0,
    'hide_empty'=> false
);
$categories = get_categories($args); // 这将返回默认的 'category' 分类,而不是 'pdf_cat'
foreach( $categories as $category ){
    echo '<option><a class="ctg" href="'. get_category_link( $category->term_id ) .' ">' . $category->name . '</a></option>';
}
?>

这段代码的问题在于,get_categories()函数忽略了post_type参数,它总是返回默认的category分类。

正确方法:使用 get_terms()

要获取自定义分类法pdf_cat下的所有术语,应使用get_terms()函数,并明确指定taxonomy参数。

<?php
$terms = get_terms([
    'taxonomy'   => 'pdf_cat', // 指定要获取的自定义分类法 slug
    'hide_empty' => false,     // 是否隐藏没有关联文章的术语
    'orderby'    => 'name',    // 按照名称排序
    'order'      => 'ASC',     // 升序排列
]);

if ( ! empty( $terms ) && ! is_wp_error( $terms ) ) {
    echo '<select>';
    foreach ( $terms as $term ) {
        // 使用 get_term_link() 获取自定义分类法术语的链接
        echo '<option><a class="ctg" href="' . esc_url( get_term_link( $term->term_id, $term->taxonomy ) ) . '">' . esc_html( $term->name ) . '</a></option>';
    }
    echo '</select>';
}
?>

在上述代码中:

  • 'taxonomy' => 'pdf_cat':这是关键,它告诉WordPress我们想要获取pdf_cat分类法下的术语。
  • 'hide_empty' => false:即使某个术语当前没有关联任何pdf文章,也会被显示出来。
  • get_term_link( $term->term_id, $term->taxonomy ):这是获取自定义分类法术语链接的正确函数。它需要术语ID和分类法slug作为参数。

根据自定义分类法术语查询文章

当用户点击某个自定义分类术语的链接后,您可能需要在新页面上显示属于该术语的所有自定义文章类型pdf的文章。同样,这里也存在与默认分类查询混淆的常见错误。

错误示例(应避免):

以下是尝试使用get_the_category()和cat参数来查询自定义文章类型pdf的常见错误方式:

<?php
// 这是一个错误示例,因为 get_the_category() 和 'cat' 参数不适用于自定义分类法
$cat = get_the_category(); // 这将获取当前文章的默认 'category',而不是 'pdf_cat'
$cat = $cat[0];
$catname = get_cat_name($cat->

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
wordpress seo
wordpress seo

WordPress网站SEO优化方法有:1、选择一个SEO友好的主题,具有清晰的代码结构,快速的加载速度和响应式设计;2、使用SEO插件,优化你的标题标签,元描述,关键字,XML站点地图等;3、优化你的内容,内容是SEO优化的核心;4、优化你的网站速度;5、创建友好的URL;6、使用内部链接;7、优化图像;8、使用社交媒体;9、定期更新你的网站;10、监控和分析你的网站等等。

435

2023.09.18

wordpress下载后怎么安装
wordpress下载后怎么安装

安装前准备:确保服务器满足要求、获取安装文件、创建数据库。上传 wordpress 文件。创建数据库和用户。运行安装程序:选择语言、输入数据库信息、网站标题和管理员信息。安装 wordpress。安装后配置:设置永久链接、安装主题、安装插件、创建内容。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

336

2024.04.15

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

37

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

136

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

47

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

90

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

102

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

226

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

504

2026.03.04

热门下载

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

精品课程

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

共137课时 | 13.4万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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