get_comment_pages_count

函数


get_comment_pages_count ( $comments = null, $per_page = null, $threaded = null )
参数
  • (WP_Comment[])
    $comments
    Optional. Array of WP_Comment objects. Defaults to `$wp_query->comments`.
    Required:
    Default: null
  • (int)
    $per_page
    Optional. Comments per page.
    Required:
    Default: null
  • (bool)
    $threaded
    Optional. Control over flat or threaded comments.
    Required:
    Default: null
返回值
  • (int) Number of comment pages.
定义位置
  • wp-includes/comment.php
    , line 992
引入
2.7.0
弃用

Calculates the total number of comment pages.

function get_comment_pages_count( $comments = null, $per_page = null, $threaded = null ) {
	global $wp_query;

	if ( null === $comments && null === $per_page && null === $threaded && ! empty( $wp_query->max_num_comment_pages ) ) {
		return $wp_query->max_num_comment_pages;
	}

	if ( ( ! $comments || ! is_array( $comments ) ) && ! empty( $wp_query->comments ) ) {
		$comments = $wp_query->comments;
	}

	if ( empty( $comments ) ) {
		return 0;
	}

	if ( ! get_option( 'page_comments' ) ) {
		return 1;
	}

	if ( ! isset( $per_page ) ) {
		$per_page = (int) get_query_var( 'comments_per_page' );
	}
	if ( 0 === $per_page ) {
		$per_page = (int) get_option( 'comments_per_page' );
	}
	if ( 0 === $per_page ) {
		return 1;
	}

	if ( ! isset( $threaded ) ) {
		$threaded = get_option( 'thread_comments' );
	}

	if ( $threaded ) {
		$walker = new Walker_Comment;
		$count  = ceil( $walker->get_number_of_root_elements( $comments ) / $per_page );
	} else {
		$count = ceil( count( $comments ) / $per_page );
	}

	return $count;
}