導讀:主題文件構在開始製作 WordPress 主題之前,首先得了解 WordPress 主題到底由哪些文件構成,你得清楚 WordPress 程序是怎樣與主題文件連接的。以
在開始製作 WordPress 主題之前,首先得了解 WordPress 主題到底由哪些文件構成,你得清楚 WordPress 程序是怎樣與主題文件連接的。以下是 WordPress 默認主題 default 文件夾下的所有模板文件:

看了上圖,可能你還摸不着頭腦,到底這些文件是幹什麼的。 WordPress 的主題是用 PHP 編寫的,而不是純 HTML + CSS,所以模板文件的後綴名是.php,如果你想精通 WordPress 的主題製作,完美控制你的博客,最好要熟悉 PHP 編程。要是不會 PHP 編程怎麼辦?就做不了 WordPress 主題了嗎?那也不是,至少看完本系列教程,你也能夠掌握基本的 WordPress 主題製作方法。下面是 WordPress 主題文件層次結構,它會告訴你:當 WordPress 顯示特定的頁面類型時,會使用哪個模板文件呢?只有瞭解了以下主題層次結構,你才能知道你的 WordPress 主題到底需要寫哪些文件。
怎麼看下面的文件層次結構?
以主頁為例,下面有 2 個文件 home.php 和 index.php,WordPress 程序會從你的主題文件夾中依次查找這兩個文件,如果找到 home.php,則使用 home.php 作為博客首頁模板,即使你的主題文件夾中有 index.php;如果 home.php 未找到,則使用 index.php 作為首頁模板;如果 home.php 和 index.php 都找不到,你的主題將不會被 WordPress 識別,等於廢物。
主頁:
- home.php
- index.php
文章頁:
- single-{post_type}.php – 如果文章類型是 videos(即視頻),WordPress 就會去查找 single-videos.php(WordPress 3.0 及以上版本支持)
- single.php
- index.php
頁面:
- 自定義模板 – 在 WordPress 後台創建頁面的地方,右側邊欄可以選擇頁面的自定義模板
- page-{slug}.php – 如果頁面的縮略名是 news,WordPress 將會查找 page-news.php(WordPress 2.9 及以上版本支持)
- page-{id}.php – 如果頁面 ID 是 6,WordPress 將會查找 page-6.php
- page.php
- index.php
分類:
- category-{slug}.php – 如果分類的縮略名為 news,WordPress 將會查找 category-news.php(WordPress 2.9 及以上版本支持)
- category-{id}.php -如果分類 ID 為 6,WordPress 將會查找 category-6.php
- category.php
- archive.php
- index.php
標籤
- tag-{slug}.php – 如果標籤縮略名為 sometag,WordPress 將會查找 tag-sometag.php
- tag-{id}.php – 如果標籤 ID 為 6,WordPress 將會查找 tag-6.php(WordPress 2.9 及以上版本支持)
- tag.php
- archive.php
- index.php
作者:
- author-{nicename}.php – 如果作者的暱稱為 rami,WordPress 將會查找 author-rami.php(WordPress 3.0 及以上版本支持)
- author-{id}.php – 如果作者 ID 為 6,WordPress 將會查找 author-6.php(WordPress 3.0 及以上版本支持)
- author.php
- archive.php
- index.php
日期頁面:
- date.php
- archive.php
- index.php
搜索結果:
- search.php
- index.php
404 (未找到) 頁面
- 404.php
- index.php
附件頁面:
- MIME_type.php – 可以是任何 MIME 類型 (image.php, video.php, audio.php, application.php 或者其他).
- attachment.php
- single.php
- index.php
詳細説明,請看 WordPress 官方文檔 (如果你能看懂英文):
http://codex.WordPress.org/Template_Hierarchy