在WordPress中,注册自定义文章后,像默认的文章类型 post 一样,也需要给新文章类型注册分类方法,这时候就需要使用 register_taxonomy 函数。
函数原型:
register_taxonomy( string $taxonomy, array|string $object_type, array|string $args = array() ): WP_Taxonomy|WP_Error
参数说明:
$taxonomy 分类方法的key。不得超过32个字符,只能包含小写字母、数字和下划线。
$object_type 与哪个文章类型绑定。
$args 分类方法的其他参数。包含以下参数:
labels,一个分类的标签数组。默认情况下,标签标签用于非树形分类的分类方法,分类标签用于树形分类的分类方法。具体包含哪些 label ,可以参考文章:《WordPress函数:get_taxonomy_labels 分类相关的标签》
description,一个简单的描述、简介。
hierarchical,是否是树形分类-是否允许分类有父子关系。默认 false。
public,分类法是否打算通过管理界面或由前端用户公开使用。
publicly_queryable,分类法是否可公开查询。如未设置,使用 public 的值。
show_ui,是否生成并允许在管理员中管理该分类法中的术语的UI。如未设置,使用 public 的值。
show_in_menu,是否在管理菜单中显示分类法。如果为true,则分类法显示为对象类型菜单的子菜单。如果为false,则不显示任何菜单。如未设置,使用 public 的值。
show_in_nav_menus,使此分类法可用于在导航菜单中进行选择。如未设置,使用 public 的值。
show_in_rest,是否支持 REST API。如果希望在块编辑器中使用,也需要设置为 true。
rest_base,在 REST API 路由中的前缀,默认同 $taxonomy 。
rest_namespace,在 REST API 路由中的 namespace,默认同 'wp/v2' 。
rest_controller_class,REST API 中 Controller 的类名。默认为:'WP_REST_Terms_Controller'。
show_tagcloud,是否在“标签云”小工具中显示。默认同 $show_ui。
show_in_quick_edit,是否在快速编辑面板中显示。默认同 $show_ui。
show_admin_column,是否在文章列表中显示。默认 false。
meta_box_cb,为属性面板提供一个回调函数。如果未设置,树形结构分类方法使用:post_categories_meta_box();非树形结构分类方法使用:post_tags_meta_box()。如果设置为 false,则不显示属性面板。
meta_box_sanitize_cb,属性的“消毒”函数。在新增或编辑该分类属性时,会使用这个函数保证属性值符合要求。
capabilities,一个数组。新增/编辑/删除等,对权限的要求。manage_terms-默认'manage_categories';edit_terms-默认'manage_categories';delete_terms-默认'manage_categories';assign_terms-默认'edit_posts';
rewrite,路径重写相关。true,默认$slug=$taxonomy;false,关闭重写;或提供一个数组,包含如下:slug-自定义路径部分。with_front-是否应使用 WP_Rewrite::$front 预处理置换结构,默认true。hierarchical 是否是树形结构分类方法,默认false。ep_mask-Assign an endpoint mask. Default EP_NONE。
query_var,设置此分类法的查询var键。默认的$taxonomy键。如果为false,则无法在中加载分类法?{query_var}={term_slug}。如果是字符串,查询?{query_var}={term_slug}将有效。
update_count_callback,工作原理很像钩子,因为它将在计数更新时被调用。附加到post类型的分类法的默认_update_post_term_count(),它在对对象进行计数之前确认对象已发布。附加到其他对象类型(如用户)的分类法的默认_update_generic_term_count()。
default_term,设置一些默认值。name-默认名称,slug-默认slug,description-默认描述。
sort,该分类法中的术语是否应按照提供给 wp_set_object_terms() 的顺序进行排序。默认为null,相当于false。
args,这是args里又包含了一个args。要在此分类法的 wp_get_object_terms() 中自动使用的参数数组。
_builtin,这个分类法是一个“内置”的分类法。仅供内部使用!默认值为false。
注意:
register_taxonomy 必须在 init 钩子执行之后再使用才有效。
关于 WordPress 的分类方法学,可以参考文章:《WordPress 中 Categories, Tags 及 Taxonomies 的区别》
-
FluentSMTP一款功能强大且免费的WordPress SMTP插件FluentSMTP是一款功能强大且免费的SMTP插件,它支持为WordPress配置多个SMTP发送服务器。
-
追格小程序V2.5.8更新发布追格小程序是一款采用积木式理念的微信小程序构建框架,它巧妙融合了Uniapp与WordPress技术,打造出一个开源且无加密限制的开发环境。
-
WordPress必备:使用wp_get_theme()函数获取当前主题详情在WordPress中,wp_get_theme() 函数用于获取当前启用的主题或指定主题的信息。这个函数返回一个 WP_Theme 对象,该对象包含了主题的详细信息,如主题名称、版本、模板目录、样式表目录等。
-
Redis Object Cache WordPress对象缓存插件Redis Object Cache是一款功能强大、易于使用的WordPress对象缓存插件。通过合理配置和优化,可以显著提高网站的访问速度和用户体验。
-
如何禁用WordPress自动生成的768、1536、2048像素及-scaled缩略图追格小编分享过两篇关于禁止自动裁剪微缩的内容,有兴趣的同学可以看看
-
Table Block by RioVizual 专为WordPress Gutenberg编辑器设计的表格插件Table Block by RioVizual是一款功能多且易于使用的WordPress表格插件。它提供了丰富的定制选项和预设计模板库,使得创建和编辑表格变得轻松快捷。
暂无评论,抢个沙发...