本記事は広告が含まれる場合があります WordPressテーマ

WordPress子テーマとは?設定方法・作り方を解説

WordPress(ワードプレス)のテーマファイルを編集する場合、子テーマを利用することでメンテナンス性が向上します。

ここではWordPressで子テーマを作成する方法を説明していきます。
 

WordPress子テーマの概要
 

ワードプレスをレイアウトをカスタマイズしようと思っています。今のテーマのPHPファイルやCSSファイルとかを編集すれば良いんですよね??

WordPressには子テーマという機能があって、PHPなどをカスタマイズする場合は子テーマを利用するようにしましょう。

 

 

子テーマとは?子テーマの仕組みとできること

親テーマの機能を引き継いだ差分テーマ

WordPressの子テーマは、親テーマの機能とスタイルを継承したテーマです。

子テーマで各種phpファイルやfunctions.php、CSS、JavaScriptなどをカスタマイズできます。

WordPress子テーマの概要
 

既存のテーマと独立して子テーマでカスタマイズすることで、親テーマをバージョンアップしても子テーマは影響を受けなくなります。

ただし、子テーマを利用しても、親テーマのテンプレート・仕様が大幅にアップデートされた場合は、子テーマの再メンテナンスが必要になる場合があります。
 

親テーマをカスタマイズした場合の注意点

親となるテーマのファイルをそのままカスタマイズした場合、テーマをアップデートするとカスタマイズした内容が全てリセットされます。※実質アップデートできなくなります。

適用している既存のテーマのファイルをそのままカスタマイズした場合、そのテーマをアップデートすると自分でカスタマイズした内容が全てリセットされる
 

なお、ここでいうカスタマイズとはテーマファイルに対してPHPやHTML・CSSなどを編集・追加することです。管理画面での設定変更した内容がバージョンアップで消える訳ではないので安心してください。
ここでいうカスタマイズとはテーマファイルに対してPHPやHTML・CSSなどを編集・追加することです。管理画面での設定変更した内容がバージョンアップで消える訳ではないので安心してください。
 

CSS編集だけなら追加CSSが簡単でおすすめ

WordPressでは、テーマカスタマイザーから追加CSSという機能を利用できます。簡単なCSSの編集のみでしたら子テーマを使わず追加CSSから設定できます。

追加CSSを利用するには、WordPressにログインした状態でカスタマイズボタンを押下します。
WordPress カスタマイズ
 

追加CSSを押下します。
WordPress カスタマイズ>追加CSS
 

CSS編集画面で任意のCSS設定を行うことができます。
WordPress カスタマイズ>追加CSSからCSSの編集する
 

この追加CSSで編集した内容はテーマのテンプレートを直接編集していないため、テーマが更新されても内容がクリアされることはありません

小規模なCSS設定であればこの追加CSS機能を利用。HTML、PHPやJavascriptまで編集する場合は子テーマといったような使い分け方をすると良いでしょう。

■追加CSSと子テーマのできることの違い

子テーマ 追加CSS
用途 本格的にテーマカスタマイズしたい場合に向いている 数行〜数十行の小規模なCSS設定のみで済む場合に向いている
CSSの追加編集
テンプレート(xxx.php)の追加・編集 ×
難易度 やや難しい 簡単
更新方法 ファイルを修正してFTPでファイルアップロード Web上の管理画面で更新
注意点 子テーマとはいえ、親テーマのPHPファイルの仕様やバージョンが大幅に変わった場合、再度子テーマのPHPファイルなどを再メンテナンスしなければならない場合があります。 追加CSSはテーマごとに設定保持されているので、追加CSSを設定した後で親テーマ→子テーマに切り替えると一旦リセットされます。(事前にコピーして再設定する必要があります。)

 
なお、追加CSSはテーマごとに設定が保存されているため、テーマを切り替えるとCSS設定はクリアされますので注意してください。

関連【追加cssとは】wordpressで追加CSSの使い方・CSS編集方法
 

WordPress子テーマの設定(公式サイトから入手)

ここでは、公式サイトなどから子テーマファイルをダウンロード入手して設定する方法をご紹介します。
 

【STEP1】公式サイトから子テーマサンプルを入手する

有名なテーマの場合は、「テーマ名 子テーマ」で検索すると、配布元から子テーマのサンプルファイルが配布されていたり、手順が載っている場合があります

※配布されておらず、自作が必要な場合は「child-theme-make」をご参照ください。

まずは、「テーマ名 子テーマ」で検索してみましょう。

例. Lightningの子テーマ
lightning 子テーマで検索
 

公式サイトから子テーマをダウンロードします。
Lightning公式サイトから子テーマをダウンロードする
 

【STEP2】追加CSSなどテーマカスタマイザーの設定を控えておく

子テーマを有効化する前に、追加CSSなどテーマカスタマイザーの設定を控えておきましょう。

親テーマの追加CSSでCSSを記述している場合、子テーマを有効化するとCSSの記述がリセットされます。

子テーマを有効化する前に追加CSSの内容をメモ帳などにコピーしておきましょう。※子テーマに切り替えた後で再度追加CSSに貼り付けてください。

追加CSSで設定
 

このほか、外観>カスタマイズのカスタマイザーの設定が一部リセットされることも多いので、既存の設定内容を確認しておきましょう。

カスタマイザーを色々設定している場合は「Customizer Export/Import」などのプラグインを利用してデータをエクスポート・インポートすることも可能です。
 
(※)WordPressのテーマをバージョンアップ・更新する際は、万一のためにバックアップを取得して元に戻せるようにしておきましょう。
 

関連WordPressカスタマイズ方法とカスタマイザーの使い方
関連【UpdraftPlusの使い方】バックアップ設定・復元方法と注意点
 

【STEP3】子テーマをアップロード・有効にする

つぎに子テーマをアップロード・有効化していきます。

WordPressの管理者画面で外観>テーマを選択します。
WordPress管理画面>テーマを選択
 

テーマのアップロードボタンを押下します。
テーマのアップロードボタンを押下する
 

テーマを選択ボタンを押下します。
テーマを選択ボタンを押下する
 

ダウンロードした子テーマzipファイルを選択します。
ダウンロードしたLightningの子テーマzipファイルを選択する
 

テーマをインストールします。
テーマをインストールする
 

テーマを有効化します。
テーマを有効化する
 

最後にサイト表示を見て確認します。色設定やデザインレイアウトは子テーマに切り替えたことでリセットされていることが多いので、カスタマイザーから調整しましょう。

サイト表示を見て確認する
 

(任意)子テーマで色々なカスタマイズを行う

ここからは自分のカスタマイズしたい内容に応じて自由に子テーマをカスタマイズしていきます。
 

style.cssに任意のスタイルを記述してカスタマイズできます。
CSSを追記編集する
 

functions.phpに独自の関数や動作処理を記述してカスタマイズすることもできます。
任意の関数などを定義・設定できる
 

また、親テーマのphpファイルを参考に自分の好きなようにカスタマイズしていくこともできます。

たとえば、footer.phpをカスタマイズしたいときは親テーマのfooter.phpを子テーマにコピーして、子テーマ内のfooter.phpをカスタマイズできます。

親テーマのPHPをカスタマイズする
 

親テーマのファイルをコピーしてカスタマイズすることで、元に戻したい場合に親テーマのファイルを比較したり、差し替えたりすることで元に戻すことができます。

逆にファイルを移動すると親テーマに元のファイルがなくなるため、元に戻したくなった時に戻すのが困難になる可能性がありますので、移動ではなくコピーして使いましょう。
 

そのほか子テーマでファイルを増やして独自のカスタム投稿タイプを作成したり、親テーマの既存のファイルをカスタマイズしたり、など自分の好きなようにカスタマイズが可能です。
 

子テーマを使ってもカスタマイズのしすぎには注意

子テーマで親テーマの主要PHPファイル(header.phpやfooter.php、single.phpやpage.phpなど)を子テーマにコピーしてカスタマイズしすぎるとメンテナンス性が悪くなります。

たとえば親テーマのバージョンが1.0時代のfooter.phpを子テーマにコピーして利用した後、時間が経ち親テーマのバージョンが4.0になったとします。

この場合、他のテンプレートファイルはバージョン4.0時代のものだが、footer.phpだけバージョン1.0時代がベースになったものを利用していることになり、不具合が発生する場合があります。
親テーマと子テーマのバージョンの違いによる 不整合発生のリスクについて
 

そのため、子テーマとはいえ、カスタマイズ内容によっては、親テーマのバージョンが上がれば子テーマのメンテナンスが必要になる場合もあるので、注意しましょう。

親テーマを直接変更するとバージョンアップで消えてしまうのでテンプレートファイルの改変は子テーマの方が良いのですが、「テンプレートファイルの改変 = バージョンアップで新しい機能についていけなくて不具合を引き起こす可能性がある」ので、できるだけテンプレートでの改変をせずにアクションフックやフィルターフックで改変できるものはそちらで対応する事をおすすめします。
参考記事)子テーマでのカスタマイズ | Lightning公式サイトより引用

メンテナンス性をできるだけよくするために、functions.phpでフックというWordPressの仕組みを利用してカスタマイズする方法がおすすめです。

関連WordPressフックとは?アクションフック・フィルターフックの使い方

 

WordPress子テーマを1から自作する方法

子テーマが事前に用意されていない場合、1から自作することもできます。ここでは、WordPress子テーマを1から自作する方法をご紹介します。
 

【STEP1】必要最小ファイル構成で子テーマを自作する

子テーマは、少なくとも 1つのディレクトリ(子テーマディレクトリ)と、2つのファイル(style.css と functions.php) から構成されます。以下の図が子テーマの最小構成図です。

WordPress子テーマを自作する
 

必要なフォルダ・ファイルは以下の通りです。

必要なフォルダ・ファイル

  • style.css
  • functions.php(※)

(※)fuctions.phpを使わなくても子テーマとして動作しますが、親テーマのCSSを正しく継承するためにはfunctions.phpは実質必須になります。
関連WordPress functions.phpとは?意味や書き方・記載場所

 

Twenty Twenty Oneというテーマを利用して1から子テーマを作成する手順を記載します。

以下は本記事作成時の環境です。

まず子テーマ用のフォルダを作成します。フォルダの名前はなんでもOKですが、親テーマ名-childなどわかりやすい命名がおすすめ
子テーマ用のフォルダを作成します。フォルダの名前はなんでもOKですが、親テーマ名-childなどわかりやすい命名がおすすめ

 
functions.phpとstyle.cssを新規作成します。
functions.phpとstyle.cssを新規作成します
 

style.cssの中身を記述する

次にstyle.cssにテーマ名 (Theme Name)や親テーマのディレクトリ名(Template)を記載します。

 

Theme Nameは子テーマの名前。名前は構いませんが「親テーマ名-child」などが分かりやすくておすすめです。

Templateは親テーマのディレクトリ名(フォルダ名)。ここではtwentytwentyoneです。
 

■style.cssの内容
style.cssの内容

そのほか、下記のように必要に応じて項目を追加することもできます。省略しても構いません。

 

functions.phpの中身を記述する

続けてfunctions.phpに親テーマのCSSを明示的に読み込む設定を行います。

一般的にはfunctions.phpには以下のように記載します。(通常は下記をコピー&ペーストで大丈夫ですが、親テーマがstyle.min.cssを使っているなど名称が違う・複数のCSSを利用している場合など、親テーマによっては必要に応じて読み替えて設定する必要があります。)

 

■functions.phpの内容
functions.phpの内容
 

これで子テーマの最低限の内容ができあがりました。
 

【STEP2】作成した子テーマをインストール・有効化する

作成した子テーマをインストール・有効化していきましょう。


 

フォルダやファイルをレンタルサーバーにFTPソフトなどを利用してアップロードする必要があります。FTPソフトがない方は下記よりFileZillaをインストールしておきましょう。

参考無料FTPツール FileZilla の使い方 Mac・Windows対応

 
FTPソフトなどで作成したフォルダをサーバー上の下記テーマフォルダにアップロードします。
FTPソフトなどで作成したフォルダをサーバー上の下記テーマフォルダにアップロード
 

外観>テーマを開き、子テーマを有効化します。
子テーマを有効化します
 

 
サイトを開き表示に問題ないことを確認します。
サイトを開き表示に問題ないことを確認します
 

(補足)「screenshot.png」(サイズ:880x660)

子テーマディレクトリに「screenshot.png」(サイズ:880x660)という画像ファイルを作成しておくと、上記のようにテーマ選択時にサムネイルが表示されます。

screenshot.png(880px * 660px)を作成

外観>テーマ。screenshot.pngがサムネイルになっている

 

まとめ

今回はWordPress子テーマとはなにか、子テーマの作成方法について説明しました。

親テーマを継承した子テーマを作成しておくことで、親テーマをバージョンアップしても子テーマは影響を受けなくなります。

PHPファイルなどを編集する際は親テーマではなく子テーマを利用する方法が推奨されているやり方です。
 

WordPress子テーマの概要
 

子テーマを自分流にカスタマイズすることでWordPressをカスタマイズすることができます。

なお、その他のWordPressの使い方は「【総まとめ版】初心者向けWordPress(ワードプレス)の使い方」をご参照ください。

今回は以上になります。最後までご覧いただきありがとうございました。

 

 

「業者に任せたけど、更新ができない」「本で独学は時間がかかりすぎる・・」そんなお悩みの方も多いのではないでしょうか。

個別指導形式のスクールでは、自分の知りたいことをピンポイントで学習・達成でき、自分で更新もできるというメリットもあります。

教室の無料事前相談もしておりますので、まずはお気軽にご登録ください。

詳細はこちら

YouTubeチャンネル開設しました!

WEBST8 YouTube Channel 開設
最大月間50万PVの当ブログをベースに、Youtube動画配信にてWordPress、ホームページ作成、ブログのことについてお役立ち情報を随時配信していきます。

ご興味ある方はぜひチャンネル登録をしていただけますと幸いです。

検索して記事を見つける

探したいキーワードを入力・検索して記事を見つけたい方はこちら

-WordPressテーマ
-