この記事は最後に更新してから1年以上経過しています。
説明
get_postsと query_postsは、どちらも複数の投稿情報を取得することができる便利な関数である。パラメータとして指定できる内容も共通しているものが多く、query_postsがより詳細なパラメータを指定でき、高機能になっている。まずは、パラメータで指定できる意味(目的)が同じキーワードを見ていこう。
意味 | get_postsのキーワード | query_postsのキーワード |
---|---|---|
取得件数 | numberposts | posts_per_page |
取得開始位置 | offset | offset |
ソート対象 | orderby | orderby |
ソート順 | order | order |
取得する投稿情報ID | include | post__in |
除外する投稿情報ID | exclude | post__not_in |
投稿情報タイプ | post_type | post_type |
取得・除外するカテゴリID | category | cat |
カスタムフィールドの名前 | meta_key | meta_key |
カスタムフィールドの値 | meta_value | meta_value |
次に、query_postsにのみ存在する主なキーワードを見てみよう。
キーワード | 意味 |
---|---|
s | 検索文字 |
category_name | カテゴリ名 |
tag | 投稿タグのスラッグ |
author | 投稿者ID |
author_name | 投稿者名 |
このように、query_postsはget_postsの検索機能を内包し、さらにプラスアルファの検索機能を備えていることを確認できたわけだが、この2つの関数には検索機能のほかに本質的な違いがある。それは、グローバル変数へ影響を及ぼすかどうか。query_postsの検索結果はさまざまなグローバル変数に影響を及ぼすが、get_postsの検索結果にはそういったことがない。
具体的な使い方の違いを少し紹介する。
$posts1 = get_posts( 'category=1' );
$posts2 = query_posts( 'cat=1' );
<?php while ( have_posts() ) : the_post(); ?>
// ここに処理を記述
<php endwhile; ?>
次は、サイドバーに特定のカテゴリの投稿記事の見出しを表示するケース。この場合は、get_postsを使用するほうがいい。
<ul>
<?php
$info_posts = query_posts( 'cat=1' );
foreach ( $info_posts as $info ) {
echo '<li>'.$info->post_title.'</li>';
}
?>
</ul>
今度は、キーワード検索で特定のカテゴリのみを検索する場合。こちらは、query_postsを使用するほうがいいだろう。具体的な使い方としては、テーマ内のsearch.phpの冒頭で次のような処理を行えばいい。
<?php
global $query_string;
query_posts( $query_string.'&cat=1,2,3' );
?>
get_postsとquery_postsのおおよその違いはこんな感じだ。
2011/8/1追記:「時代はWP_Queryなのか」も合わせてお読みください。
最終更新 : 2018年05月27日 10:51
関連
お勧め
get_userdata(2022年2月4日 更新)
mixed get_userdata( int $user_id )
ユーザIDを指定し、マッチするユーザ情報を取得する。
has_filter(2022年11月8日 更新)
mixed has_filter( $tag, [ mixed $function_to_check = false ] )
WordPressタグにフィルターが登録されているか調べる。
wp_add_object_terms(2013年8月6日 更新)
mixed wp_add_object_terms( int $object_id, mixed $terms, mixed $taxonomy )
投稿情報などにタクソノミーを追加する。
is_tag(2018年5月27日 更新)
bool is_tag( [ mixed $slug = '' ] )
要求されているページが、タグアーカイブページか調べる。
add_meta_box(2014年11月16日 更新)
void add_meta_box( string $id, string $title, string $callback, string $page [, string $context = 'advanced' [, string $priority = 'default' [, array $callback_args = null ] ] ] )
投稿ページに独自のメタボックスを表示する。