Home  >  Article  >  CMS Tutorial  >  Unleashing the Power of WP_Query: Exploring Properties and Methods

Unleashing the Power of WP_Query: Exploring Properties and Methods

王林
王林Original
2023-09-04 08:05:06655browse

释放 WP_Query 的力量:探索属性和方法

Welcome to another installment in the “Mastering WP_Query” series. How are we doing so far? I hope you enjoy these tutorials as much as we enjoyed writing them.

In this tutorial, you will learn about the properties and methods of the WP_Query class. But first, I thought it would be appropriate to discuss "properties" and "methods" in classes.

Can we?

What exactly are properties and methods?

In PHP, there is a simpler way to write code: object-oriented programming, or OOP. For OOP, we use "classes" as blueprints — I got this terminology from a classic post on Code Tuts, "Object-Oriented PHP for Beginners" by Jason Lengstorf:

For example, a class is like the blueprint of a house. It defines the shape of the house on paper, clearly defining and planning the relationship between the different parts of the house, even if the house does not exist.

(Remember WP_Query is an important class in the core of WordPress.)

When you understand the concept of PHP classes, "properties" and "methods" become very easy to understand because these words are just synonyms for "variables" and "functions". Yes, Attributes are variables of the PHP class, and Methods are functions of the PHP class.

Now that we've covered what they are, let's learn about each property and method.

Warning: It is unwise to change properties directly. As the Codex says, you should use the methods of WP_Query to interact with them.

Attributes of WP_Query class

Let's start with the properties or variables of the WP_Query class.

Query string: $query

This property stores the query passed to the $wp_query object.

Query variable array: $query_vars

This property stores an associative array of $query's variables (and their values).

Query object: $queried_object

This attribute stores the object of the current query, such as the $post object (if it is a post query) or the $author object (if it is an author query).

Query object ID: $queried_object_id

This attribute stores the ID of the query object.

Query returned posts: $posts

This property stores the posts returned from the query.

Number of posts displayed: $post_count

This attribute stores the number of posts currently queried.

The number of posts returned by the query: $found_posts

This property stores the number of posts in the SQL query that do not contain the LIMIT clause.

Number of pages:$max_num_pages

This property stores the number of pages - calculated by dividing $found_posts by $posts_per_page.

Index of current post: $current_post

This attribute stores the index number of the current item in the loop. For example, if the loop has just started, it is -1 and is incremented via the next_post() method.

Current post: $post

This attribute stores the current post.

Conditional label Boolean value: $is_{conditional}

The following properties are stored as Boolean values ​​and provide information about the current post status:

  • $is_single: Checks if it is a single post of any post type (except "attachment" and "page" post types).
  • $is_page: Check if it is a page.
  • $is_archive: Check whether it is an archive page.
  • $is_preview: Check whether it is a post preview.
  • $is_date: Check if it is an archive page based on date.
  • $is_year: Check if it is an archive page based on year.
  • $is_month: Check if it is a month-based archive page.
  • $is_time: Check if this is an archived page based on time (hourly, minute, or second).
  • $is_author: Check if it is the author's archive page.
  • $is_category: Check if it is a category archive page.
  • $is_tag: Check whether it is a tag archive page.
  • $is_tax: Check whether it is a classified archive page.
  • $is_search: Check whether it is a "search results" page.
  • $is_feed: Check whether it is a feed.
  • $is_comment_feed: Check if it is a comment feed.
  • $is_trackback: Check whether it is a reference.
  • $is_home: Check whether it is the main blog page.
  • $is_404: Check whether it is a 404 error page.
  • $is_comments_popup: Check if it is a comment popup window.
  • $is_admin: Check if it is an admin panel.
  • $is_attachment: Check whether it is an attachment.
  • $is_singular: Checks if it is a single post for any post type (including "attachment" and "page" post types).
  • $is_robots: Check whether it is a query to the robots.txt file.
  • $is_posts_page: Check if it is a "posts page" (set on the "Reading Settings" page of the admin panel).
  • $is_paged: Check whether it is a paging query and not the home page.

Methods of WP_Query class

Now that we are done with the properties, let's move on to the methods (functions) of the WP_Query class.

init()

This method simply initializes the object, setting all properties to NULL, 0, or FALSE.

parse_query( $query )

This method uses the $query attribute to parse the query and populate all other attributes (except $posts, $post_count, $post and $current_post).

parse_query_vars()

This method re-parses the query variables.

get( $query_var )

This method gets the given query variable.

Settings ($query_var, $value)

This method sets the given query variable to a specific value.

&get_posts()

This method returns the posts requested by the query and populates the $posts and $post_count properties.

next_post()

This method increments the $current_post index and advances to the next post in $posts, returning the current post object. (This method must be used within a loop to work properly.)

the_post()

This method sets the global $post variable with data from the next post. (This method must be used within a loop to work properly.)

have_posts()

This method checks if there are any posts left to process, and if not, returns FALSE. (This method must be used before the loop to work properly.)

rewind_posts()

This method simply resets the $current_post and $post properties.

&query( $query )

This method calls its two sibling methods: parse_query() and get_posts(), and returns the result of get_posts().

get_queried_object()

This method returns the query object. (Sets $queried_object if not already set.)

get_queried_object_id()

This method is similar to the above method and returns the ID of the query object ($queried_object_id).

Quick Tip: If there is an & symbol before a method, it means that the method returns by reference.

Today’s summary

I hope I was able to make it clear to you what "properties" and "methods" mean for classes. If you understand the purpose of the properties and methods of the WP_Query class, I can say I did a good job!

Do you have anything to add to this article? Share your thoughts with us in the comments section below. If you liked this article, don’t forget to share it with your friends.

See you in the next part of this series!

The above is the detailed content of Unleashing the Power of WP_Query: Exploring Properties and Methods. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn