WordPressでブログを始めたいという人には無縁かと思いますが、Web制作のWordPress案件には大きく分けて2種類あります。
- 有料テーマを使った制作
- オリジナルテーマ制作
有料テーマを使った制作では『Snow Monkey』や『SWELL』といった有料テーマを使い制作します。クラウドソーシングや、そこまでデザインにこだわりがないサイトで使われることが多い印象です。
そしてオリジナルテーマ制作では、コーディングしたHTMLやCSSを元にテーマを自作していきます。
オリジナルテーマ制作は特に制作会社からの案件に多く、私の場合WordPress案件はほぼオリジナルテーマ制作です。
もちろん有料テーマを使ったコードをあまり書かなくても済む『ノーコード、ローコード』と呼ばれる制作もあり、それだけでも十分稼いでいる人もいます。
ただし、オリジナルテーマ制作が出来ないと制作会社とのお仕事は難しいと思います。
そこで今回はHTMLやCSSで静的ページのコーディングが完了し、これからそのファイルを使ってWordPressのオリジナルテーマ制作したい人向けの記事となります。
最初から最後まで書くとボリュームが半端ないので、何回かに分けて書いていきます。
WordPressオリジナルテーマの作り方は、当記事を含め以下の記事があります。
WordPressオリジナルテーマ制作の記事
また、記事の最後にはWordPressのおすすめ教材をご紹介させて頂きます。
WordPressオリジナルテーマの作り方
まず、静的サイトをWordPress化すると何が出来るようになるのかですが、
- 投稿ページが作れる(ブログが書ける)
- プラグインを使って簡単にお問い合わせフォームが作れる
- ファイルをいじらなくてもWordPressの管理画面からテキストや画像の差し替えが可能
- 便利なプラグインで様々なカスタマイズ可能
というメリットがあります。
静的サイトとの一番大きな違いは投稿機能です。
この投稿機能により、常に最新の情報を発信出来るというわけですね。
そして本題のオリジナルテーマの作り方ですが、ざっくり書くと以下のようになります。
- HTML / CSS / JavaScriptなどでコーディングする(静的サイト)
- WordPressのローカル環境を構築(PC上で擬似的なWordPressサイトを構築)
- 必要なテーマフォルダやテンプレートファイルを作成
- テンプレートファイルにHTMLで書いたコードをコピペ
- テンプレートファイルに画像やパスを読み込む為のコードを書く
- WordPressの管理画面で色々設定
最後に『色々設定』と思い切り省略しましたが、ここは次回以降の記事で解説していきます。
今回メインで解説するのは、③の『必要なテーマフォルダやテンプレートファイルを作成』になります。
WordPressのローカル環境を構築(Local使用)
まずは、WordPressのローカル環境を構築します。
通常、WordPressのオリジナルテーマを作成する時は、自分のPC内でローカル環境を構築することが多いと思います。
- ローカル環境を構築
- テストサーバーにアップ
- 本番サーバーにアップ
といった感じです。
ローカル環境の構築方法については以下の記事を参照下さい。
Local by Flywheel(現Local)でWordPressのローカル環境を構築する方法
続きを見る
Local by Flywheelの名称はLocalに変わりました
また、
という人は以下の記事を参照下さい。
エックスサーバーの場合はこちら。
【エックスサーバー】ポートフォリオやWordPressサイトの公開方法【テスト環境にも使える!】
続きを見る
ConoHa WINGの場合はこちら。
【ConoHa WING】ポートフォリオやWordPressサイトの公開方法【テスト環境にも使える!】
続きを見る
自分でレンタルサーバーを契約しておくことはWeb制作では必須なので、まだ契約していない人はレンタルサーバーの選び方を以下の記事から参照下さい。
【徹底比較】ブログ・ポートフォリオにおすすめレンタルサーバー3選と選び方を解説
続きを見る
WordPressオリジナルテーマに使うテーマフォルダを作成
まずは、先ほどLocalで作ったローカル環境の場所を確認します。
これから作るテーマフォルダを入れる場所、『themes』というフォルダの中になります。
Macの場合
⇒ (サイト名) ⇒ app ⇒ public ⇒ wp-content ⇒ themes
Windowsの場合
⇒ (サイト名) ⇒ app ⇒ public ⇒ wp-content ⇒ themes
もしくはLocalの『Go to site folder』をクリックすると、appフォルダが入っているサイトのフォルダーが開きます。
あとは『app ⇒ public ⇒ wp-content ⇒ themes』とthemesフォルダを開きましょう。
themesフォルダ内はこうなっています。
twenty~というのはデフォルトで用意されてるテーマですね。
例えば、ここに『test』という名前のテーマフォルダを作るとこうなります(フォルダ名は変更可能)
そしてこの『test』というテーマフォルダに、次から作成するテンプレートファイルをどんどん入れていきます。
WordPressのテンプレートファイルを作成
これからテンプレートファイルを作成していきます。
テンプレートファイルは、ファイル名によってそれぞれ役割が決まっています。
例えば、
- front-page.php → トップページ用テンプレート
- header.php → ヘッダー用テンプレート
- footer.php → フッター用テンプレート
という感じです。
なので、以下のようにはなりません。
- front-page.php → ヘッダーのコード ❌
- header.php → 投稿ページのコード ❌
- footer.php → トップページのコード ❌
サイトにもよりますが、オリジナルテーマ制作で作成するページは以下のような種類があります。
- トップページ
- 固定ページ
- 投稿一覧ページ
- 投稿個別ページ
- カテゴリー一覧ページ
- カスタム投稿一覧ページ
- カスタム投稿個別ページ
- カスタム投稿カテゴリーページ
- 投稿者別一覧ページ
- タグ一覧ページ
- 検索結果ページ
- 月別アーカイブページ
- 404ページ
トップページ、固定ページ、404ページ以外は全て投稿系になります。
もちろんカスタム投稿がない場合もありますし、投稿者一覧やタグ一覧は滅多に使わないので、上記全て作成するという訳ではありません。
テンプレートファイル一覧
それでは先ほどのページの種類にはどのテンプレートを使うか見てみます。
- index.php(テーマの必須ファイル)
- style.css(スタイルシート・必須ファイル)
- functions.php(テーマで使う関数を書くファイル)
- front-page.php(トップページ)
- header.php(ヘッダー)
- footer.php(フッター)
- page-〇〇.php(固定ページ)
- home.php(今回は記事一覧ページとして使用)
- single.php(個別記事ページ)
- category.php(カテゴリー一覧ページ)
- archive-〇〇.php(カスタム投稿一覧ページ)
- single-〇〇.php(カスタム投稿個別ページ)
- taxonomy-〇〇.php(カスタム投稿カテゴリー一覧ページ)
- author.php(投稿者別一覧ページ)
- tag.php(タグ一覧ページ)
- searchform.php(検索フォーム)
- search.php(検索結果ページ)
- date.php(月別アーカイブページ)
- 404.php(404ページ)
中にはページではないテンプレートやファイルもあります(ヘッダーやフッターは共通パーツ、style.cssはテーマの必須ファイルなど)
また、非常に沢山あるように見えますが滅多に使わないファイルもあり、上記ファイルを全て使う事はまずありません。
今回の記事は基本的にファイルの準備だけで、各テンプレートファイルに書くコードなどは次の記事以降で解説したいと思います。
それでは順番に解説していきます。
index.php(テーマの必須ファイル)
『index.php』はテーマとして認識させる為に必須のファイルで、『index.html』とは中身も別物です。
『index.php』の中身は空のまま(コード書かなくてOK)で大丈夫ですが、これがないとテーマとして認識されません。
まずこちらがテーマフォルダを作る前です。
これだけ見ても良く分からないと思うので、themesフォルダ内に『test』というフォルダを作ります。
こちらがtestフォルダを作る前。
そしてこちらがtestフォルダを作った後。
するとこのように変わります。
下の方に先ほどは表示されてなかった文章が表示されています。
壊れているテーマとちょっと怖い事が書いてありますが、焦らなくて大丈夫です。
テーマフォルダの中に『index.php』と『style.css』がないとこのように表示され、テーマとして認識されていないという状態になります。
まずはテーマフォルダに『index.php』というファイルを作成して置きましょう(themesフォルダにある『index.php』(testと同じ階層にある方)は別物です)
style.css(スタイルシート)
そして『index.php』に続き、テーマとして認識させるのに必要なもう1つのファイルが『style.css』です。
『style.css』の役割はこちら。
- テーマとして認識させる為の必須ファイル
- コメントヘッダーでテーマの情報を入力
- テーマのCSSを記入可能
テーマのCSS、つまりデザインを整えるCSSをここに書くことも出来ますが、
- テーマを認識させる為のstyle.css(今回のstyle.css)
- デザインを整える為のstyle.css(静的サイトのコーディングで作成したstyle.css)
で分けた方がいいでしょう。
コメントヘッダーの書き方
style.cssのコメントヘッダーの書き方は以下のようになります。
@charset "utf-8";
/*
Theme Name: テーマ名
Theme URI: テーマのホームサイトのURL
Description: テーマの説明
Author: 作者の名前
Author URI: 作者のサイトのURL
Version: バージョン
*/
これがないと先ほどのようにテーマとして認識されません。
この中で必須なのは『Theme Name』だけとなるので、それ以外は項目ごと削除しても大丈夫です。
@charset "utf-8";は日本語のコメントを入れる場合は必要となります
『Theme Name』は作成したテーマフォルダと同じ名前でいいかと思います(今回で言えば『test』)
ここまででテーマフォルダの中はこのようになります。
この『style.css』と『index.php』がテーマフォルダにあると、このように表示されます。
『壊れているテーマ』ではなく、テーマとして認識されました。
あとはこのテーマを選択して有効化すればOKです。
また、上記はとなりの『Twenty Twenty-Two』のようにサムネイル画像がありません。
サムネイル画像は特に設定する必要はないのですが、もし設定したい場合は以下の記事を参照下さい。
【WordPress】テーマのスクリーンショット(サムネイル画像)の設定方法
続きを見る
次からは一般的に必要となるテンプレートファイルを書いていきます。
これから紹介するテンプレートファイルは説明が色々書いてありますが、とりあえずは必要なファイルを作ってテーマフォルダに入れるだけでOKです(中身の書き方は別記事で解説しています)
functions.php(テーマで使う関数を書くファイル)
『functions.php』はちょっと特殊なファイルで、カスタマイズするのに必要なコードをまとめて書いておくプラグインのようなファイルです。
必要な機能を後から追加していくような場所なので、最初は必要なコードだけ書いておけば大丈夫です。
例えば静的ページではCSSやJavaScriptは、headタグやbodyタグ直前などから読み込むと思います。
WordPressでもheadタグが書いてある『header.php』から読み込んでも大丈夫ですが、基本的にはfunctions.phpから読み込むのが一般的なようです。
理由の1つとしては、ファイルの読み込みやカスタマイズに必要なコードを一元管理出来るというのがあります。
functions.phpについては以下の記事を参照下さい。
WordPressオリジナルテーマの作り方③(functions.php編)
続きを見る
front-page.php(トップページ)
トップページのテンプレートとして使われるファイルには『front-page.php』のほかにも『home.php』や『index.php』があります。
もしこの3つのファイルが全てあった場合は『front-page.php』がトップページとして使われるので、『front-page.php』をトップページとして使うのがおすすめです。
『front-page.php』がなければ『home.php』がトップページ
さらに『home.php』がなければ『index.php』がトップページになります。
同じトップページを表示出来るテンプレートにも優先順位があるという事です。
トップページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方②(トップページ編)
続きを見る
テンプレートの階層についての理解は非常に重要なので、こちらの記事も一度は見ることをおすすめします。
WordPressオリジナルテーマ制作に必要なテンプレートの階層まとめ
続きを見る
headar.php(ヘッダー)
『header.php』は名前の通りヘッダー部分のファイルなのですが、HTMLファイルでの<header>から</header>までのことではありません。
1行目の<!DOCTYPE html>から</header>までとなります。
そしてこの<!DOCTYPE html>から</header>までを切り取って張り付けたものが『header.php』となります。
このような事をする理由や、コードの書き方については次の記事で解説します。
header.phpの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方②(トップページ編)
続きを見る
footer.php(フッター)
『footer.php』も<footer>から</footer>ではなく、<footer>から一番最後の行である</html>までを切り取ったものです。
footer.phpの作り方は以下の記事を参照下さい。
続きを見るWordPressオリジナルテーマの作り方②(トップページ編)
home.php(今回は記事一覧ページとして使用)
『今回は』と書いたのは、先ほど説明しましたが『front-page.php』がなかった場合はトップページにもなることがあるからです。
ただし今回は『front-page.php』があるので、トップページには『home.php』ではなく『front-page.php』が使われます。
記事一覧ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑥(記事一覧ページ編)
続きを見る
page-〇〇.php(固定ページ)
『page-〇〇.php』は固定ページ用のテンプレートファイルとなります。
これは投稿ページと違い、会社概要やお問い合わせといった頻繁に更新されないようなページとなります。
もちろん情報が更新されればテンプレートファイルを編集すればOKですが、クライアントが直接テンプレートファイルを編集することはまずないと思うので、通常はカスタムフィールドを設定して管理画面から編集できるようにすることが多いです(カスタムフィールドの話は一旦置いておいて大丈夫です)
また〇〇の部分には固定ページとして分かりやすい名前をつけましょう。
例えば会社概要ページであれば『page-company.php』などがいいかと思います。
なので『page-〇〇.php』というファイルは、固定ページの数だけ作ってください。
例えば、
- page-company.php(会社概要ページ)
- page-contact.php(お問い合わせページ)
- page-recruit.php(採用ページ)
などなど。
また、固定ページは『page-〇〇.php』ではなく『page.php』というテンプレートファイルを使う方法もありますが、ここではこの方法は使いません。
固定ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方④(固定ページ編)
続きを見る
single.php(個別記事ページ)
これはブログページ(投稿ページ)になります。
WordPressの管理画面で『投稿 ⇒ 新規追加』で作成した記事のページになり、投稿した記事情報を取り出すためのファイルになります。
これは一覧ページではなく個別ページとなります(一覧ページは『home.php』にしています)
個別記事ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑧(個別記事ページ編)
続きを見る
category.php(カテゴリーページ)
これは特定のカテゴリーだけを表示する一覧ページとなります。
ページのレイアウトは記事一覧ページと同じ場合がほとんどだと思うので中身もほぼ同じになりますが、一覧ページとは特定のカテゴリーだけ表示させる為のコードが違います。
カテゴリーページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑨(カテゴリーページ編)
続きを見る
archive-〇〇.php(カスタム投稿一覧ページ)
これはカスタム投稿があった場合に必要なテンプレートファイルで、例えばカスタム投稿タイプが『news』であれば『archive-news.php』といったファイルを作ります。
◯◯の部分については固定ページと同じような感じで、カスタム投稿の種類の数だけ作成します。
カスタム投稿一覧ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑩(カスタム投稿編)
続きを見る
single-〇〇.php(カスタム投稿個別ページ)
これもarchive-◯◯.phpと考え方は同じです。
カスタム投稿個別ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑩(カスタム投稿編)
続きを見る
taxonomy-〇〇.php(カスタム投稿カテゴリー一覧ページ)
これもarchive-◯◯.phpと考え方と似てますが、これについては◯◯の部分はタクソノミースラッグになります。
このテンプレートファイルは最初に作らなくてもいいかと思うので、一旦保留で大丈夫です。
カスタム投稿カテゴリー一覧ページは以下の記事を参照下さい。
続きを見るWordPressオリジナルテーマの作り方⑩(カスタム投稿編)
author.php(投稿者別一覧ページ)
通常の記事一覧ページは全ての投稿者の記事が表示されますが、これは投稿者別の一覧ページになります。
ページのレイアウトは基本的に記事一覧ページと同じになるかと思います。
もちろん投稿者が複数いないと意味のないテンプレートで、小規模のサイトでは滅多に使わないと思います。
tag.php(タグ一覧ページ)
これはタグ一覧ページになります。
ページのレイアウトは基本的に記事一覧ページと同じになるかと思います。
ただ私は2年間の実務で一度も使った事がありません・・・
searchform.php(検索フォーム)
これはページではなく、検索フォームのテンプレートファイルになります。
あまり使う機会はないと思いますが、もし検索フォームを作る必要があれば思い出してみて下さい。
検索結果フォームの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑫(検索フォーム・検索結果ページ編)
続きを見る
search.php(検索結果ページ)
これは検索結果ページになります。
『searchform.php』と名前が似ていますが、こちらはページのテンプレートファイルとなり、ページのレイアウトは基本的に記事一覧ページと同じになるかと思います。
検索結果ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑫(検索フォーム・検索結果ページ編)
続きを見る
date.php(月別アーカイブページ)
これは日付別一覧ページになります。
ページのレイアウトは基本的に記事一覧ページと同じになるかと思います。
これも滅多に使う機会はないと思います。
月別アーカイブページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑬(月別アーカイブページ編)
続きを見る
404.php(404ページ)
404ページとは、ページが見つからなかった時に表示されるエラーページです。
これがなくてもエラーページは表示されますが、表示されるのはWordPressが用意した画面なので、ちゃんとデザインしたページで表示したい場合に使います。
404ページの作り方は以下の記事を参照下さい。
WordPressオリジナルテーマの作り方⑪(404ページ編)
続きを見る
あとはcssやjsのフォルダを作成して、事前に作成しておいた『style.css』をcssフォルダに入れればひとまず完了です。
画像で見るとこんな感じですね(ここでは『test』という名前のテーマフォルダを作成しました)
先ほども書きましたが全て使うわけではないので、必要なテンプレートファイルだけ作成しましょう。
WordPressオリジナルテーマ制作のおすすめ教材
勉強方法は書籍、動画、プログラミングスクールなど色々あり、個人によって向き不向きがあると思います。
そこでタイプごとにご紹介させて頂きたいと思いますが、その前におすすめの勉強方法は以下になります。
- 分かるところまでどんどん進める
- 勉強に詰まる
- 無視して次に進む or 他の教材などを使う
- もう一度詰まった場所を見てみる
- 理解できるようになっている
これからご紹介する教材と一緒にこのブログを読み進めて頂けると、より理解が深まるかと思います。
書籍
WordPressに関する本も沢山ありますが、ここでおすすめするのは2冊です。
いちばんやさしいWordPressの教本
こちらは以前私が持っていた本で、タイトル通りやさしいというかWordPressを1から勉強したい人向けの内容となっています。
Lightningという無料のWordPressテーマを使った制作方法など載っています。
ちなみにLightningを使ったサイト制作についてはこちらのブログでもご紹介しています。
初心者からちゃんとしたプロになる WordPress基礎入門
こちらは私も個人的にお世話になっているちづみさんが書かれた本になります。
WordPressの本はこれまで何冊か購入しましたが、ダントツで読みやすいです。
ちなみに私が初めてにして唯一購入したコーディング教材がちづみさんのnoteでした。
また、初心者から実務経験者まで活用出来る非常におすすめの本となっています(電子書籍で購入しました)
動画教材
WordPressを動画で学びたい人はこちらの教材がおすすめです。
本と違って動画だと手を動かしながら確認出来るのでいいですね。
こちらはUdemyの有料教材ですが、かなりの頻度でセールを行っていて90%オフとか良くあるので出来ればそのタイミングを狙いましょう(私はセール時に購入しました)
『WordPressの動画教材と言えばコレ』というくらい有名な教材で、私を含め周りでも購入している人がたくさんいます。
もちろんUdemyはWordPress以外の教材もたくさんあるので、気になる教材がセールをやっていたら購入を検討しても良いかも知れませんね。
プログラミングスクール
プログラミングスクールも色々ありますが『Web制作に特化したスクール』であればデイトラ一択かと思います。
開校1年で受講生が7,000人を突破したオンラインスクールで、スクールと言ってもオンラインなので自宅で受講することが出来ます。
WordPressのカリキュラムは『Web制作コース上級編』にあります。
デイトラはTwitterをやっていれば分かりますが、悪い評判は見たことがなく、叩かれやすいWeb制作業界において非常にクリーンなイメージです。
カリキュラムの質が高いのはもちろん、他のスクールと比べて圧倒的なコスパかつ買い切りとなっています。
そしてカリキュラムはどんどん更新されるので『情報が古い』ということもなく、メンターに質問が出来る点も独学だと挫折しやすいWeb制作の勉強においてはおすすめです。
私の周りも『Web制作を始めるならまずデイトラを勧める』という人も多いです。
デイトラについては以下の記事を参照下さい。
デイトラのサービス内容・コース料金・評判・口コミをまとめて紹介【Web制作におすすめのスクール】
続きを見る
また、
という人は、完全無料で30日間Web制作を学べるZeroPlus Gateがおすすめです。
ZeroPlus Gateの評判と特徴やメリットを解説【無料プログラミングスクール】
続きを見る
他にもDMM WEBCAMPやテックアカデミーにもWordPressコースがあるので、まずは無料相談を受けてみるといいと思います。
DMM WEBCAMPの評判・口コミ・注意点など徹底解説【未経験者向けプログラミングスクール】
続きを見る
テックアカデミーの評判・口コミ・注意点など徹底解説【プログラミングスクール受講者数No1!】
続きを見る
初心者向け実践型WordPress教材
これはBrainという知識共有プラットフォームで販売されている教材になります(👇画像クリック出来ます)
こちらは学習面以外にも制作会社とのやり取りの流れや、特典では『作業前・納品前のチェックシート』『営業文のサンプル』『見積もり計算シート』など『実務に対する不安を払拭できる内容』となってます。
LP1本のコーディング費が安くても3万円くらいだと考えれれば、軽く1日で回収出来るので早めに『安心』を購入しましょう。
詳細はこちらからどうぞ👇
今だけ!購入者限定の10大特典付き🎁
実務で使った2年分のコーディング&WordPressメモまとめ集
これは私が販売しているものですが『教材』ではなく『コード集(コードスニペット集)』という感じです。
こちらは、1,100部以上売れています。
詳細については以下の記事を参照ください(Brain販売ページと重なる内容もあります)
初心者向き教材!コーディング&WordPressコードスニペット集【コピペで使える】
続きを見る
まとめ:WordPressオリジナルテーマの作り方はファイルの準備から!
今回はテンプレートファイルを作成しただけなので、次の記事以降でこれらのテンプレートファイルに書くコードなどを解説していきます。
またテンプレート階層の概念はとても重要です。記事の途中でも載せましたが、テンプレート階層についてを参考にして下さい。
WordPressオリジナルテーマ制作に必要なテンプレートの階層まとめ
続きを見る
以上になります。