#WordPress でクエリ投稿機能を使用するにはどうすればよいですか?
クエリ投稿は記事を呼び出す非常に使いやすい機能で、特定範囲の様々な記事を同一ページ上に表示することができます。 WordPress の強力なクエリ投稿。気に入った友人は、
推奨事項を参照してください: 「wordpress チュートリアル」
クエリ投稿は非常に簡単です。関数を使用して記事を呼び出すと、同じページ上に複数の特定範囲の記事を表示することができます。たとえば、特定のカテゴリ、タグ、日付、著者など、異なる範囲の記事のリストを呼び出すことができます。これらの記事リストは、WordPress ページのコンテンツを大幅に充実させ、SEO に利益をもたらします。中古の科学者は、記事を呼び出すためにクエリ投稿で使用される関数を整理しました。それらについては以下で説明します。
まず、クエリ投稿の一般的な書き方です。通常、最初にクエリが定義され、次に記事のループ コードが追加され、その後クエリがリセットされます。
コードは次のとおりです:
<?php //定义要显示的文章范围查询 query_posts(); //文章回圈 if ( have_posts() ) : while ( have_posts() ) : the_post(); ?> <!–这边是当判断符合时列出的文章清单,你可以用< ?php the_xxx(); >系列来显示相关的文章资讯–> <?php endwhile; else: ?> <!–这边是显示抓无资料时要跑出来的错误讯息–> <?php endif; //重置查询(这是为了避免之后的查询资料因为上面这段查询而混乱掉) wp_reset_query(); ?>
以下の関数はすべて上記のフレームワークに基づいており、query_posts(); に対応するパラメータを入力するだけで、必要な記事の範囲を表示できます。
1. カテゴリパラメータ (記事分類パラメータ)
cat - カテゴリ番号を入力してカテゴリ内の記事を表示します
category_name - カテゴリ名を入力してカテゴリを表示します
category__and 内の記事 – 複数のカテゴリに含まれる記事を同時に表示します (識別するカテゴリ番号を入力するだけです)
category__in – このカテゴリ内の記事を表示しますが、サブカテゴリは含まれません記事(カテゴリ番号のみ入力で識別可能)
category__not_in - 特定カテゴリの記事を除き、他のカテゴリやサブカテゴリの記事を表示(カテゴリ番号のみ入力で識別可能)
コードは次のとおりです:
<?php //仅显示分类编号为4的文章(包括子分类文章) query_posts(‘cat=4′); //仅显示分类名称为Codex的文章(包括子分类文章) query_posts(‘category_name=Codex ‘); //显示多个分类内的文章(包括各子分类文章) query_posts(‘cat=2,6,17,38′); //除了分类编号为3的文章(包括子分类文章),其他文章都显示 query_posts(‘cat=-3′); //显示同时有分类编号为2及6的文章 query_posts(array(‘category__and’ => array(2,6))); //显示分类编号为6的文章(但不包括子分类文章) query_posts(array(‘category__in’ => array(6))); //除了分类编号为2及6的文章,子分类及其他分类文章都显示 query_posts(array(‘category__not_in’ => array(2,6))); ?>
2. タグ パラメータ
tag - タグ名を入力すると、そのタグを含む記事が表示されます
tag_id - Enterタグ番号を指定して、そのタグを含む記事を表示します。 記事
tag__and – 複数の特定のタグに一致する記事を表示します (識別するタグ番号を入力することに限定されます)
tag__in – いずれかのタグに一致する記事を表示します特定のタグ (識別するためのタグ番号の入力に限定) 識別)
tag__not_in – このタグが含まれる記事は表示されません (識別するためのタグ番号の入力に限定)
tag_slug__and – 該当する記事を表示します
tag_slug__in – 特定のタグの 1 つに一致する記事を表示します (識別するためのタグ名の入力に限定されます)
コード
<?php //仅显示标签带有cooking的文章 query_posts(‘tag=cooking’); //仅显示标签带有bread或baking的文章 query_posts(‘tag=bread,baking’); //仅显示标签带有bread及baking及recipe的文章 query_posts(‘tag=bread+baking+recipe’); //仅显示标签带有编号37及47的文章 query_posts(array(‘tag__and’ => array(37,47)); //仅显示标签带有编号37或47的文章 query_posts(array(‘tag__in’ => array(37,47)); //仅显示标签不带有编号37或47的文章 query_posts(array(‘tag__not_in’ => array(37,47)); ?>
3, 著者パラメータ (author パラメータ)
author - 著者番号を入力すると、著者によって発行された記事が表示されます
author_name - 著者を入力します著者が公開した記事を表示するための名前
コードは次のとおりです:
<?php //仅显示作者编号为3的文章 query_posts(‘author=3′); //仅显示作者编号不为3的文章 query_posts(‘author=-3′); //仅显示作者名称为Harriet的文章 query_posts(‘author_name=Harriet’); ?>
4. Sticky Post Parameters (スティッキー ポストのパラメーター)
コードは次のとおりです。
<?php //仅显示置顶文章 array(‘post__in’=>get_option(‘sticky_posts’)) //将文章的置顶属性清除掉,以正常文章顺序排序(例如发表日期)显示出来 caller_get_posts=1 ?>
記事を表示しますが、固定記事は表示しません。
コードは次のとおりです。
<?php query_posts(array(“post__not_in” =>get_option(“sticky_posts”))); ?>
カテゴリ番号 6 の記事を表示し、1 ページに 3 つの記事を表示し、このカテゴリの記事の先頭属性をクリアし、記事の通常の順序で並べ替えます。 (出版日など)が表示されます。
コードは次のとおりです:
<?php query_posts(‘cat=6&posts_per_page=3&caller_get_posts=1′); ?>
5. 投稿およびページのパラメータ (記事およびページングのパラメータ)
コードは次のとおりです:
<?php //显示文章编号为27的文章 ‘p’ => 27 //显示文章代称为about-my-life的文章 ‘name’ => ‘about-my-life’ //显示分页编号为7的分页 ‘page_id’ => 7 //显示分页代称为about的分页 ‘pagename’ => ‘about’ //当文章超过5篇时就仅显示5篇文章并且搭配换页程式码显示换页连结,设为-1则不换页全部显示。 ‘posts_per_page’ => 5 //当设定为6时就显示6篇文章,设为-1则显示范围内的全部文章。 ‘showposts’ => 6 //仅显示文章编号为5,12,2,14,7的这5篇文章 ‘post__in’ => array(5,12,2,14,7) //仅显示文章编号不为5,12,2,14,7的其他全部文章 ‘post__not_in’ => array(6,2,8) //显示文章类型为分页的文章,预设值为post (文章),可以使用的数值有attachment(媒体档页面), page(分页), post(文章),或revision(修订)。 ‘post_type’ => ‘page’ //显示文章状态为公开性质的文章,可以使用的数值有pending(审核中), draft(草稿), future(排程), private(私人), trash(垃圾) 。 ‘post_status’ => ‘publish’ //显示文章范围内的第93页 ‘post_parent’ => 93 ?>
6. Time Parameters (time Parameters)
12月20日に公開された記事の一覧を表示します。
コードは次のとおりです。
<?php query_posts(‘monthnum=12&day=20′); ?>
今週公開された記事のリストを表示します。
コードは次のとおりです。
<?php $week = date(‘W’); $year = date(‘Y’); query_posts(‘year=’ . $year .‘&w=’ .$week ); ?>
過去 30 日間に公開された記事のリストを表示します。
コードは次のとおりです:
<pre name="code" class="php"><?php function filter_where($where = ”) { $where .= ” AND post_date > ‘” . date(‘Ym-d’, strtotime(‘-30 days’)) . “‘”; return $where; } add_filter(‘posts_where’, ‘filter_where’); query_posts($query_string); ?>
7. Orderby パラメータ (配置順序パラメータ)
<?php //依照发表作者排列 orderby=author //依照日期排列 orderby=date //依照标题排列 orderby=title //依照最后编辑时间排列 orderby=modified //依照分页顺序排列(仅适用于分页) orderby=menu_order // (不知道XD…) orderby=parent //依照文章编号排列 orderby=ID //随机排列 orderby=rand //依照自订栏位数值排列 orderby=meta_value //依照预设排列 orderby=none //依照回响数排列 orderby=comment_count ?>
8. ページネーション パラメータ (ページネーション パラメータ)
コードは次のとおりです:
<?php //当值设定true时则为不分页显示,直接显示全部文章 nopaging=true //显示每页文章显示10篇 posts_per_page=10 //页数,例如当设定为6时则就表示跳到第6页 paged=6 //排列顺序,ASC为按时间顺序排列文章,若是DESC则是反向显示文章 order=ASC ?>
9. 組み合わせ適用例
カテゴリ番号 3 の 2004 年に公開された記事を表示します。
コードは次のとおりです。
<?php query_posts(‘cat=3&year=2004′); ?>
カテゴリ番号 1 と 3 の記事を、1 ページに 2 件ずつタイトル順に並べて表示します。
<?php query_posts(array(‘category__and’=>array(1,3),‘posts_per_page’=>2,‘orderby’=>title,‘order’=>DESC)); ?>
はトップページにのみ表示され、カテゴリ番号 13 の月に記事が公開されます。
<?php if (is_home()) { query_posts($query_string . ‘&cat=13&monthnum=’ . date(‘n’,current_time(‘timestamp’))); } ?>
カテゴリ番号1、タグ「リンゴ」の記事を表示します。
rree以上がワードプレスでクエリ投稿機能を使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。