wp_set_post_categories

函数
wp_set_post_categories ( $post_ID = 0, $post_categories = array(), $append = false )
参数
  • (int) $post_ID Optional. The Post ID. Does not default to the ID of the global $post. Default 0.
    Required:
  • (int[]|int) $post_categories Optional. List of category IDs, or the ID of a single category. Default empty array.
    Required:
    Default: array()
  • (bool) $append If true, don't delete existing categories, just add on. If false, replace the categories with the new categories.
    Required:
    Default: false
返回值
  • (array|false|WP_Error) Array of term taxonomy IDs of affected categories. WP_Error or false on failure.
定义位置
相关方法
wp_get_post_categorieswp_set_post_catswp_set_post_termswp_list_categorieswp_get_post_cats
引入
2.1.0
弃用
-

wp_set_post_categories: 这个函数设置与一个文章相关的类别。它接受文章的ID和一个类别ID的数组。

为文章设置分类。

如果没有提供类别,就会使用默认的类别。

function wp_set_post_categories( $post_ID = 0, $post_categories = array(), $append = false ) {
	$post_ID     = (int) $post_ID;
	$post_type   = get_post_type( $post_ID );
	$post_status = get_post_status( $post_ID );

	// If $post_categories isn't already an array, make it one.
	$post_categories = (array) $post_categories;

	if ( empty( $post_categories ) ) {
		/**
		 * Filters post types (in addition to 'post') that require a default category.
		 *
		 * @since 5.5.0
		 *
		 * @param string[] $post_types An array of post type names. Default empty array.
		 */
		$default_category_post_types = apply_filters( 'default_category_post_types', array() );

		// Regular posts always require a default category.
		$default_category_post_types = array_merge( $default_category_post_types, array( 'post' ) );

		if ( in_array( $post_type, $default_category_post_types, true )
			&& is_object_in_taxonomy( $post_type, 'category' )
			&& 'auto-draft' !== $post_status
		) {
			$post_categories = array( get_option( 'default_category' ) );
			$append          = false;
		} else {
			$post_categories = array();
		}
	} elseif ( 1 === count( $post_categories ) && '' === reset( $post_categories ) ) {
		return true;
	}

	return wp_set_post_terms( $post_ID, $post_categories, 'category', $append );
}

常见问题

FAQs
查看更多 >