新・元地方の中規模印刷会社で苦悩するWebデザイナー改めWebディレクターの日記

自由な20代、窮屈な30代を経て、遂に40代になっちまったWebディレクター&パソコン講師の覚書と思う言(こと)。略称【ちほちゅう】

*

WordPress(ワードプレス)のヘッドライン表示は「query_posts」じゃなくて「get_posts」 #wp

      2014/11/09

  • このエントリーをはてなブックマークに追加

1年以上前の記事です。内容が古い可能性があります。

プログラムのプロではないのですがときたまプログラムのようなものは書くことがあって、
今回、「つぶくま」にヘッドライン表示を設置した時に気付いたポイントを紹介しておきます。

スポンサーリンク
 

まずは最終的にこのかたちになったというのがこちら。

<div id="headline">【お知らせ】 
<?php
$myposts = get_posts('numberposts=3');
foreach($myposts as $post) :
?>
<a href="<?php the_permalink() ?>"><?php the_title(); ?></a> 
<?php endforeach; ?>

</div>

3~4行目でデータを抽出して6行目で表示。4行目と7行目の間がループとなっています。
実は、3行目の「get_posts('numberposts=3');」のところで実際は一つのカテゴリに絞っているので「get_posts('numberposts=3&category=6');」となっていますがまあ、大方上記の通りです。
(「get_posts」では「numberposts」で記事本数、「category」で記事カテゴリーを指定することができます。)

これのベースとなっているのがプロット・ファクトリーのトップページにあるインフォメーションの部分を改造したこちら。

<div id="headline">【お知らせ】 
<?php
$myposts = query_posts('showposts=3');
foreach($myposts as $post) :
?>
<a href="<?php the_permalink() ?>"><?php the_title(); ?></a> 
<?php endforeach; ?>
</div>

ただ、これだと問題がありまして。。

つぶくまの場合はトップページ以外、全ページにヘッドラインを以下のように表示させようと思っています。
つぶくまのヘッドライン表示
上部、赤線で囲んだ部分がヘッドライン。

一方でプロット・ファクトリーはトップページのみに以下のように表示されるだけ。
プロット・ファクトリーのインフォメーション表示
同じく赤線で囲んだ部分。

実は、プロット・ファクトリーのプログラムを書き換えただけだと、固定ページは問題なく表示されるものの、投稿された各記事やカテゴリー一覧ページに入った時に抽出された記事だけが表示されてしまうのです。
これは、「query_posts」の仕様で、グローバル変数へ影響を与える関数であるから。
一方で
「get_posts」はグローバル変数へ影響を与えることはありません。
get_postsとquery_postsを使い分け:WordPress私的マニュアル

つまりは、新着記事一覧をサイト内任意の場所に表示させたい時は「query_posts」ではなく、「get_posts」を使うようにしたほうが良いということです。

ちなみにquery_postsをつかった場合はwhileを使って書くこんな方法もあります。

<div id="headline">【お知らせ】 
<?php
query_posts('showposts=3');
while ( have_posts() ) : the_post()
?>
<a href="<?php the_permalink() ?>"><?php the_title(); ?></a> 
<?php endwhile ?>
</div>

こちらをget_postsで使うにはちょっと工夫をしなければならないようです。

 - CMS, WordPress, プログラミング, 覚え書き , ,

アドセンス広告メイン

Message

メールアドレスが公開されることはありません。

  関連記事

セキュアなままでニンテンドーDSのWi-Fi通信を可能に【後編】

1年以上前の記事です。内容が古い可能性があります。最初は無線機器の設定とルーター …

モバイルサイトのスクリーンショット

1年以上前の記事です。内容が古い可能性があります。「モバイルサイトを本格的に始め …

no image
ブログにFacebookの「いいね!」ボタンをつける方法【ライブドアブログ編】

1年以上前の記事です。内容が古い可能性があります。ツイッターやらブログやらで騒が …

またまたOpenOfficeにムカッ! 困ったらファイルを閉じよ

1年以上前の記事です。内容が古い可能性があります。どうも、OpenOffice「 …

Googleアナリティクスで時間別アクセス数を見る方法

1年以上前の記事です。内容が古い可能性があります。Googleアナリティクスは非 …

Flickrの画像にまとめてリンクを入れる方法

1年以上前の記事です。内容が古い可能性があります。ブログの被リンク対策の一貫とし …

Amazon「おまかせリンク」の障害の影響でAdsenseの収益が増えている?

1年以上前の記事です。内容が古い可能性があります。これはあくまでも仮説です。 な …

no image
バグを逆手にプログラミング(CSSハック)

1年以上前の記事です。内容が古い可能性があります。livedoor ニュース & …

「くぁwせdrftgyふじこlp」ってなんの暗号?

1年以上前の記事です。内容が古い可能性があります。たまにtwitter(ツイッタ …

docomo(ドコモ)のスマホ(スマートフォン)で余計なサービスを削除(解約)する方法

1年以上前の記事です。内容が古い可能性があります。最近は、大型量販店(イオン等) …

血液型オヤジ