2
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

【初心者向け】Wordpressテーマを自作する[singular.php][single.php][page.php]

Posted at

ここでは、WPのテーマを作る上で必須のsingular.phpのコードを交えた解説を行います。
「あれ?single.phpじゃないの?」と思った方、なぜsingle.php ではなくsingular.phpなのかも含めて解説します。
とりあえずこの段階では「同じもの」と思っていただいて良いです。

ファイルの構造や解説等、Wordpress(以下、WP)のテーマを自作する際の基本的な部分は、こちらの記事で紹介しています。

とりあえず解説はいいからコードだけ、の方は以下をどうぞ。

コード(HTMLとPHP)

<?php /*
==========================================
Theme Name: Single + Page
==========================================
*/
get_header(); ?>
<div class="wrap">
    <main id="singular">
        <div class="breadcrumb-area">
            <?php output_breadcrumb(); ?>
        </div><!--//class="breadcrumb-area"-->
        <section class="content-area">
        <?php
        if(have_posts()) :
            while(have_posts()) : the_post();
        ?>
        <h2 class="sub-title"><?php the_title(); ?></h2>
        <div class="date-area">
            <span>Release</span><?php the_time('Y/m/d');?>
            <span>LastUp</span><?php the_modified_date('Y/m/d'); ?>
        </div><!--//class="date-area"-->
        <?php
        if(has_post_thumbnail()){
            echo '<figure class="thumb-img">' .get_the_post_thumbnail(). '</figure>' ;
        }
        ?>
        <div class="content-txt">
            <?php the_content();?>
        </div><!--//class="content-txt"-->
        </section><!--//class="content-area"-->
        <?php
            endwhile;
        endif;
        ?>
        </section><!--//class="content"-->
    </main>
    <?php get_sidebar(); ?>
</div><!--//class="wrap"-->
<?php
get_footer(); ?>

解説

singular.phpとは

WPのテーマを自作する際の必須ファイルです。
とは言っても、single.phppage.phpがある場合、singular.phpは不要です。(それ必須とは言わない)

WP4.3から実装され、index.phpの次に読み込まれるテーマファイルで、個別ページ(single)と固定ページ(page)をこのファイルで兼用することができます。
デザインがシンプルで、個別ページと固定ページで条件分岐を細かく分ける必要がない場合はこれ一つだけで良いので、工数が減らせて良いかなと思います。
ただ、無理にsingular.phpにする必要はなく、「single.phppage.phpがある方がいい」と言う方はそれでもいと思います。
私の場合は、出来るだけサーバの使用量を少なくしたいのと、メンテナンス性を重視してsingular.phpにしています。
そんな訳でコード内にあるTheme Name:にはSingle + Pageとなっています。

以前私が書いた記事ではシンプルで最小のファイル構成を書いています。参考にどうぞ。

必須なコード

ヘッダーを読み込むget_header();、フッターを読み込むget_footer();loop<?php if(have_posts()) : while(have_posts()) : the_post(); ?>がないと始まらないですね。
<?php endwhile; endif; ?>loopを終わらせるのも忘れずに。

コードの説明

下記の部分は、自作の「パンくずリスト」を独自の関数で読み込んでいます。

<div class="breadcrumb-area">
    <?php output_breadcrumb(); ?>
</div><!--//class="breadcrumb-area"-->

コードはこちらで記事にしていますので参考にどうぞ。

Loopのはじまり

この部分は、投稿(post)があったらloopすると言う、phpで動的にデータを取得して表示するために必須のコードで、ほぼすべてのテーマファイルで使われているので、「なんか知らんが必ず入れる」位でいいと思います。

<?php
if(have_posts()) :
    while(have_posts()) : the_post();
?>

テンプレートタグは、loopの中に置かないと動作しないものもあるので注意

タイトル

この部分は記事のタイトルを取得して表示しています。

<h2 class="sub-title"><?php the_title(); ?></h2>

公開日と更新日

この部分は、該当の投稿を公開した日をthe_time('Y/m/d')で表示し、更新日をthe_modified_date('Y/m/d')で表示しています。
内容によっては、固定ページではいらないので、このコード部分をif( !is_page()) {(固定ページじゃなかったら表示)もしくはif(is_single()) {で囲んでも良いかと思います。

<div class="date-area">
    <span>Release</span><?php the_time('Y/m/d');?>
    <span>LastUp</span><?php the_modified_date('Y/m/d'); ?>
</div><!--//class="date-area"-->

▼固定ページじゃなかったら表示

<?php if( !is_page()) { ?>
<div class="date-area">
    <span>Release</span><?php the_time('Y/m/d');?>
    <span>LastUp</span><?php the_modified_date('Y/m/d'); ?>
</div><!--//class="date-area"-->
<?php } ?>

▼個別ページだったら表示

<?php if(is_single()) { ?>
<div class="date-area">
    <span>Release</span><?php the_time('Y/m/d');?>
    <span>LastUp</span><?php the_modified_date('Y/m/d'); ?>
</div><!--//class="date-area"-->
<?php } ?>

公開日を表示する関数でthe_date()もありますが、これは使いません。
以前はthe_date()を使っていたのですが、複数の記事を同じ日に投稿した時に、それぞれの記事ごとに公開日を取得してくれないと言うことがあり使わなくなりました。Codexでも同じ日に複数の記事がある場合は、最初の記事とともに一度だけ出力される。と明記しているので仕様のようです。

the_date()と似たようなのでget_the_date()がありますが、echoを使って出力しなくてはならないのと、なんとなくgetがついている関数は、 変数に値を入れる時に使うもの と私の中でルール化しているので、変数に公開日情報を入れる必要がある場合だけ使います。

Wordpressのテンプレートタグは、似たような文言が多いのですが、使い方等かなり違うので、都度Codexで確認するのが良いと思います。

アイキャッチの表示

ここではアイキャッチを表示します。
if(has_post_thumbnail())としているのはアイキャッチ画像があったら表示するです。

<?php
if(has_post_thumbnail()){
    echo '<figure class="thumb-img">' .get_the_post_thumbnail(). '</figure>' ;
}
?>

ただ、これだとアイキャッチ画像がない場合は何も表示されないので、

<?php
if(has_post_thumbnail()){
    echo '<figure class="thumb-img">' .get_the_post_thumbnail(). '</figure>' ;
} else {
    echo '<figure class="thumb-img"><img src="' .get_template_directory_uri(). '/images/noimages.png"></figure>';
}
?>

とした方がデザインが崩れずにいいかも。
別途、imagesフォルダにnoimages.pngと言う画像を用意するのを忘れずに。

投稿内容の表示

the_content()で投稿画面で入力した内容が画像含め全部表示されます。
ただ文字の色や大きさを変える、画像へ文章を回り込ませたり、画像にキャプションを付けたりと言ったデザインの部分はここではコントロールできません。
CSSファイルにWPの独自classを追加し、専用のスタイルでデザインを整えます。
これはまた別の機会に記事にできれば。

<div class="content-txt">
    <?php the_content();?>
</div><!--//class="content-txt"-->

Loopのおわり

これを書かないとloopが止まらないで延々と繰り返し処理をしてエラーになってしまうので忘れずに。

<?php
    endwhile;
endif;
?>

まとめ

個別ページ(single)と固定ページ(page)は基本的に同じ様なことをやっているので、私はsingular.phpにまとめていますが、前述したように、single.phppage.phpがあった方が良いという方や、それぞれのページで条件分岐を色々したいという方は分けていいと思います。
コードはここに書かれているものをそれぞれのファイルにコピペしても正常に動作します。

他記事でも書いていますが、私は汎用性の高い、シンプルなファイル構成を目指しているので、兼用できる部分や少しの条件分岐を書くだけで済むのであれば、まとめてしまいたいです。
カスタム投稿を使い始めると、ついついtaxonomy-***.phpと言うファイルを増やしがちになってしまうのですが、ファイルを増やす前に、条件分岐で何とかならないかな?と常に考えて手を動かす様にしています。

10年以上WPでWEBサイト制作をしていますが、独学のため、色々間違えている個所などありましたらご指摘いただけますと幸いです。

2
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?