【说明】
判断一个单独一面是否被显示,返回 TRUE 或者 FALSE
【用法】
- <?php is_single($post); ?>
【参数】
$post
(mixed) (optional) Post ID, Post Title or Post Slug
默认: None
【返回值】
(boolean)
成功 True, 失败 false.
【示例】
- is_single();
- // 当任何文章页面被显示.
- is_single('17');
- // 当文章ID为17的被显示.
- is_single(17);
- // 当文章ID为17的被显示。 整形的参数也可以。
- is_single('Irish Stew');
- // 文章的标题为"Irish Stew"的被显示.
- is_single('beef-stew');
- // 当文章的别名 post_name (slug) 是 "beef-stew" 的 被显示.
- is_single(array(17,'beef-stew','Irish Stew'));
- // 当文章的 ID是17, 或者别名 post_name 是 "beef-stew",或者文章的标题是"Irish Stew"的返回True. 注意: 数组参数的功能是在 2.5版本添加的.
【注意】
类似功能: is_singular()
【源文件】
is_single() 在 wp-includes/query.php.
- /**
- * Is the query for a single post?
- *
- * Works for any post type, except attachments and pages
- *
- * If the $post parameter is specified, this function will additionally
- * check if the query is for one of the Posts specified.
- *
- * @see is_page()
- * @see is_singular()
- *
- * @see WP_Query::is_single()
- * @since 1.5.0
- * @uses $wp_query
- *
- * @param mixed $post Post ID, title, slug, or array of such.
- * @return bool
- */
- function is_single( $post = '' ) {
- global $wp_query;
- if ( ! isset( $wp_query ) ) {
- _doing_it_wrong( __FUNCTION__, __( 'Conditional query tags do not work before the query is run. Before then, they always return false.' ), '3.1' );
- return false;
- }
- return $wp_query->is_single( $post );
- }
- /**
- * Is the query for a single post?
- *
- * Works for any post type, except attachments and pages
- *
- * If the $post parameter is specified, this function will additionally
- * check if the query is for one of the Posts specified.
- *
- * @see WP_Query::is_page()
- * @see WP_Query::is_singular()
- *
- * @since 3.1.0
- *
- * @param mixed $post Post ID, title, slug, or array of such.
- * @return bool
- */
- function is_single( $post = '' ) {
- if ( !$this->is_single )
- return false;
- if ( empty($post) )
- return true;
- $post_obj = $this->get_queried_object();
- $post = (array) $post;
- if ( in_array( $post_obj->ID, $post ) )
- return true;
- elseif ( in_array( $post_obj->post_title, $post ) )
- return true;
- elseif ( in_array( $post_obj->post_name, $post ) )
- return true;
- return false;
- }