เรียนรู้เทคนิคสำคัญ: สร้างธีม WordPress แรกของคุณตั้งแต่เริ่มต้น

อ่าน 3 นาที
2026-03-19
2026-06-04
2,843
I earn commissions when you shop through the links below, at no additional cost to you.

การเตรียมสภาพแวดล้อมการพัฒนาและไฟล์พื้นฐาน

ก่อนเริ่มเขียนโค้ด การตั้งค่าสภาพแวดล้อมการพัฒนาท้องถิ่นที่มั่นคงเป็นสิ่งสำคัญมาก ซึ่งจะช่วยให้คุณทดสอบได้โดยไม่กระทบกับเว็บไซต์ออนไลน์ ขอแนะนำให้ใช้เครื่องมือเช่น Local by Flywheel, XAMPP หรือ MAMP เพื่อตั้งค่าสภาพแวดล้อมเซิร์ฟเวอร์ท้องถิ่นที่มี PHP และ MySQL อย่างรวดเร็ว

ถัดไป คุณจำเป็นต้องสร้างโฟลเดอร์ใหม่สำหรับธีมของคุณในโฟลเดอร์ wp-content/themes ภายในไดเรกทอรีการติดตั้ง WordPress เช่นตั้งชื่อว่า my-first-themeโฟลเดอร์นี้คือไดเรกทอรีรูทของธีมของคุณ จากนั้นคุณต้องสร้างไฟล์พื้นฐานและจำเป็นที่สุดสองไฟล์:style.cssindex.php

style.css ไฟล์ไม่เพียงแต่เป็นสไตล์ชีตของธีมของคุณ แต่ที่สำคัญกว่านั้นคือมันมีส่วนหัวข้อมูลธีม (Theme Header) ที่เขียนขึ้นในรูปแบบคอมเมนต์ CSS ส่วนหัวนี้เป็นหลักฐานเดียวที่ WordPress ใช้ในการระบุธีมของคุณ

แนะนำให้อ่าน จากศูนย์สู่หนึ่ง: คู่มือและเทคนิคการปฏิบัติจริงสำหรับการพัฒนา WordPress Theme แบบครบวงจร

/*
Theme Name: 我的第一个主题
Theme URI: http://example.com/my-first-theme/
Author: 你的名字
Author URI: http://example.com/
Description: 这是一个从零开始创建的 WordPress 主题示例。
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: my-first-theme
*/

index.php เป็นไฟล์เทมเพลตหลักของธีมของคุณ และเป็นไฟล์สำรองสุดท้ายที่ WordPress มองหาเมื่อค้นหาเทมเพลต อย่างน้อยที่สุดมันควรมีโค้ดเรียกใช้แกนหลักของ WordPress เพื่อแสดงส่วนหัวหน้า เนื้อหาลูป และส่วนท้ายหน้า

UltaHost WordPress โฮสติ้ง
การรับประกันคืนเงินภายใน 30 วัน, แบนด์วิธและฐานข้อมูลไม่จำกัด, การป้องกัน DDoS ฟรี, ซื้อ 3 ปีลดราคา 50%
<!DOCTYPE html>
<html no numeric noise key 1005>
<head>
    <meta charset="<?php bloginfo( 'charset' ); ?>">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <?php wp_head(); ?>
</head>
<body no numeric noise key 1002>
    
</body>
</html>

ทำความเข้าใจลำดับชั้นของเทมเพลตธีม

ก่อนที่จะสร้างไฟล์เทมเพลตอื่นๆ การทำความเข้าใจลำดับชั้นเทมเพลต (Template Hierarchy) ของ WordPress เป็นสิ่งสำคัญ มันกำหนดว่า WordPress จะเลือกไฟล์เทมเพลตใดมาแสดงผลสำหรับหน้าประเภทต่างๆ (เช่น หน้าหลัก หน้าโพสต์ หน้าเพจ หน้าประเภทหมวดหมู่) ตัวอย่างเช่น เมื่อเข้าถึงโพสต์เดี่ยว WordPress จะค้นหาไฟล์ตามลำดับดังนี้:single-post-{slug}.php -> single-post-{id}.php -> single.php -> singular.php -> index.php。การเข้าใจกฎนี้จะช่วยให้คุณควบคุมรูปลักษณ์ของหน้าต่างๆ ได้อย่างแม่นยำ โดยการสร้างไฟล์เฉพาะ (เช่น single.phppage.php),

แกนหลักของเทมเพลตในการสร้างธีม

ธีมที่สมบูรณ์ไม่ควรมีเพียงแค่ index.phpเพื่อให้การจัดระเบียบโค้ดและการนำกลับมาใช้ใหม่ดีขึ้น เราจำเป็นต้องแยกหน้าเว็บออกเป็นหลายส่วน และนำเข้าโดยใช้ฟังก์ชัน

แยกส่วนหัวและส่วนท้ายของหน้า

สร้าง header.php ไฟล์ สำหรับเก็บส่วนหัวของเอกสาร HTML (DOCTYPE, <head> ส่วน และส่วนเริ่มต้นของเนื้อหาหน้าเว็บ เช่น ชื่อเว็บไซต์และเมนูนำทางหลัก) ดังนั้น ให้สร้าง footer.php ไฟล์ สำหรับเก็บเนื้อหาส่วนท้ายของหน้า (เช่น ข้อมูลลิขสิทธิ์) และแท็กปิด

หลังจากนั้น ใน index.php ในนั้น คุณสามารถใช้ get_header()get_footer() ฟังก์ชัน เพื่อนำเข้า ทำให้โครงสร้างชัดเจนขึ้น

แนะนำให้อ่าน คู่มือฉบับสมบูรณ์สำหรับผู้เริ่มต้นพัฒนา WordPress Theme: สร้าง Theme แรกของคุณจากศูนย์สู่หนึ่ง

สร้างเทมเพลตแถบด้านข้าง

หากธีมต้องการแถบด้านข้าง สามารถสร้าง sidebar.php ไฟล์ ใช้ฟังก์ชัน dynamic_sidebar() เพื่อเรียกใช้แถบด้านข้างที่ลงทะเบียนในพื้นที่วิดเจ็ต ในเทมเพลตหลัก ใช้ get_sidebar() ฟังก์ชันเพื่อนำเข้า

เพื่อดำเนินการวนซ้ำโพสต์และเทมเพลตเนื้อหา

การวนซ้ำโพสต์คือหัวใจของธีม WordPress ใช้สำหรับดึงและแสดงโพสต์จากฐานข้อมูล ใน index.phpsingle.php ในนั้น เราใช้โครงสร้างลูปมาตรฐาน เพื่อควบคุมการแสดงบทความในรายการ (เช่น หน้าแรก, หน้ารวบรวม) และหน้าโพสต์เดี่ยวได้อย่างเป็นโมดูลาร์มากขึ้น สามารถสร้าง content.php หรือสร้างแยกกัน content-single.phpcontent-excerpt.php

ภายในลูป ใช้ get_template_part() ฟังก์ชันเพื่อเรียกใช้ไฟล์เทมเพลตเนื้อหาเหล่านี้ เช่น:get_template_part( 'content', get_post_format() );

hosting.com 共享主机
高性能,配备 AMD EPYC CPU、NVMe SSD 存储和 LiteSpeed,全天候24小时、全天候的专家内部支持,高级安全措施,包括 SSL、暴力破解、恶意软件和 DDoS 防护,节省高达 73%

การผสานฟังก์ชันและสไตล์ของธีม

ธีมที่ดีไม่เพียงแต่ต้องมีรูปลักษณ์เท่านั้น แต่ยังต้องเพิ่มความสามารถผ่านไฟล์ฟังก์ชันด้วย

นำเข้าไฟล์ฟังก์ชันธีม

สร้าง functions.php ไฟล์นี้ไม่ใช่ไฟล์เทมเพลต แต่เป็น “สมอง” ของธีม ใช้สำหรับเพิ่มฟังก์ชันของธีม, จดทะเบียนเมนู, แถบด้านข้าง, และนำเข้า Script กับ Style มันจะถูก WordPress โหลดอัตโนมัติเมื่อเริ่มต้นธีม

ในไฟล์นี้ คุณสามารถใช้ add_theme_support() ฟังก์ชันเพื่อเปิดใช้งานคุณสมบัติของธีม เช่น รูปภาพเด่น (Featured Image), โลโก้ที่กำหนดเอง (Custom Logo) และการรองรับแท็ก HTML5

แนะนำให้อ่าน WordPress Theme Development from Beginner to Expert: The Essential Guide to Building Personalized Websites

function my_first_theme_setup() {
    // 添加文章和评论的 RSS feed 链接到 head
    add_theme_support( 'automatic-feed-links' );
    // 启用文章缩略图功能
    add_theme_support( 'post-thumbnails' );
    // 注册一个导航菜单位置
    register_nav_menus( array(
        'primary' => __( '主导航菜单', 'my-first-theme' ),
    ) );
}
add_action( 'after_setup_theme', 'my_first_theme_setup' );

พื้นที่วิดเจ็ตการลงทะเบียน

functions.php ใน, ใช้ register_sidebar() ฟังก์ชันสามารถกำหนดพื้นที่วิดเจ็ต (Widget Areas) หนึ่งหรือหลายพื้นที่ ซึ่งอนุญาตให้ผู้ใช้ลากและวางคอมโพเนนต์ในส่วนติดต่อผู้ใช้ “วิดเจ็ต” ที่แถบด้านหลัง

function my_first_theme_widgets_init() {
    register_sidebar( array(
        'name'          =&gt; __( '主侧边栏', 'my-first-theme' ),
        'id'            =&gt; 'sidebar-1',
        'description'   =&gt; __( '在此添加小工具。', 'my-first-theme' ),
        'before_widget' =&gt; '<section id="%1$s" class="widget %2$s">',
        'after_widget'  =&gt; '</section>',
        'before_title'  =&gt; '<h2 class="widget-title">',
        'after_title'   =&gt; '</h2>',
    ) );
}
add_action( 'widgets_init', 'my_first_theme_widgets_init' );

โหลดสไตล์และสคริปต์อย่างถูกต้อง

อย่าใช้แท็ก <link><script> แท็กที่เข้ารหัสแบบฮาร์ดโค้ดเพื่อนำเข้าไฟล์ CSS และ JavaScript วิธีที่ถูกต้องคือใน functions.php ใช้ฟังก์ชัน wp_enqueue_style()wp_enqueue_script() ฟังก์ชัน และติดตั้ง (mount) ลงใน wp_enqueue_scripts บนฮุค ซึ่งช่วยให้แน่ใจว่าการพึ่งพาถูกต้องและหลีกเลี่ยงการโหลดซ้ำ

โฮสติ้งแบบแชร์ของ InterServer
共享主机每月 $2.50 USD , 首月 $0.1 USD 优惠码 tryinterserver, 461个云应用脚本,一键安装。
function my_first_theme_scripts() {
    // 加载主样式表
    wp_enqueue_style( 'my-first-theme-style', get_stylesheet_uri() );
    // 加载导航脚本,依赖 jQuery
    wp_enqueue_script( 'my-first-theme-navigation', get_template_directory_uri() . '/js/navigation.js', array('jquery'), '1.0', true );
}
add_action( 'wp_enqueue_scripts', 'my_first_theme_scripts' );

การเตรียมความพร้อมสำหรับการทำให้เป็นสากลและการเผยแพร่ธีม

การแปลธีมให้เป็นจริง

เพื่อให้ธีมของคุณสามารถใช้งานได้โดยผู้ใช้ทั่วโลก การทำให้เป็นสากล (i18n) เป็นขั้นตอนที่จำเป็น ซึ่งหมายความว่าคุณต้องห่อหุ้มสตริงทั้งหมดที่เผชิญหน้ากับผู้ใช้งานด้วยฟังก์ชันการแปล ฟังก์ชันที่ใช้บ่อยที่สุดคือ __()(ใช้สำหรับแสดงผลการแปลใน PHP) และ _e()(ใช้สำหรับส่งออกการแปลใน PHP) ในขณะเดียวกัน ในฟังก์ชันการโหลดของ style.css และ functions.php จำเป็นต้องตั้งค่าโดเมนข้อความ (Text Domain) อย่างถูกต้อง เช่นที่เราได้ตั้งค่าไว้ก่อนหน้านี้ my-first-theme

ทำการทดสอบขั้นสุดท้ายและการบีบอัด

ก่อนที่จะเผยแพร่ จำเป็นต้องทดสอบอย่างครอบคลุมในสภาพแวดล้อมที่แตกต่างกัน (PHP เวอร์ชันต่างๆ, WordPress เวอร์ชันต่างๆ) และอุปกรณ์ที่แตกต่างกัน (เดสก์ท็อป, แท็บเล็ต, โทรศัพท์มือถือ) ตรวจสอบว่าไฟล์เทมเพลตทั้งหมดทำงานได้ปกติ ฟังก์ชันต่างๆ เป็นไปตามที่คาดหวัง และสอดคล้องกับมาตรฐานการตรวจสอบธีมอย่างเป็นทางการของ WordPress

สุดท้ายนี้ ให้ลบโค้ดดีบักและความคิดเห็นทั้งหมดออก (เว้นแต่จะเป็นประโยชน์ต่อผู้ใช้) และใช้เครื่องมือ (เช่น CodeKit หรือเครื่องมือบีบอัดออนไลน์) เพื่อบีบอัดไฟล์ CSS และ JavaScript ของคุณให้มีขนาดเล็กลง จากนั้นบีบอัดโฟลเดอร์ธีมทั้งหมดเป็นไฟล์ ZIP เพื่อเตรียมส่งไปยังไดเรกทอรีธีมของ WordPress.org หรือแจกจ่ายให้ผู้ใช้

สรุป

การสร้างธีม WordPress ตั้งแต่เริ่มต้นเป็นกระบวนการเรียนรู้ที่เป็นระบบ ครอบคลุมตั้งแต่การตั้งค่าสภาพแวดล้อม ความเข้าใจในลำดับชั้นของเทมเพลต การสร้างไฟล์เทมเพลตหลัก ไปจนถึง functions.php กระบวนการทั้งหมดของการรวมฟังก์ชันขั้นสูง กุญแจสำคัญคือการปฏิบัติตามมาตรฐานการเข้ารหัสและแนวทางปฏิบัติที่ดีที่สุดของ WordPress เช่น การใช้ฟังก์ชันในตัว การนำเข้าแหล่งข้อมูลอย่างถูกต้อง การทำให้เป็นสากล ผ่านการฝึกปฏิบัติตามขั้นตอนที่อธิบายไว้ในบทความนี้ คุณจะไม่เพียงได้ธีมที่ใช้งานได้ แต่ยังเข้าใจกลไกพื้นฐานของการทำงานของ WordPress Theme อย่างลึกซึ้ง เพื่อสร้างพื้นฐานที่มั่นคงสำหรับการพัฒนา Theme ที่ซับซ้อนและเป็นมืออาชีพมากขึ้น

คำถามที่พบบ่อย (FAQ)

การสร้างธีมจำเป็นต้องเชี่ยวชาญ PHP หรือไม่?

ใช่ การเข้าใจ PHP อย่างลึกซึ้งเป็นสิ่งจำเป็นสำหรับการพัฒนา WordPress Theme แบบกำหนดเอง เนื่องจาก WordPress เองถูกเขียนด้วย PHP ไฟล์เทมเพลตทั้งหมด (เช่น index.php, single.php) และไฟล์ฟังก์ชัน (functions.php) ใช้โค้ด PHP โดยตรงเพื่อสร้างเนื้อหาแบบไดนามิก เรียกใช้ฐานข้อมูล และประมวลผลตรรกะ หากไม่มีความรู้ด้าน PHP คุณจะไม่สามารถเข้าใจและจัดการกับส่วนสำคัญของธีมได้

การพัฒนา Theme จำเป็นต้องเขียนโค้ดทั้งหมดตั้งแต่เริ่มต้นหรือไม่?

ไม่จำเป็นเสมอไป สำหรับผู้เริ่มต้น การเริ่มจากศูนย์เป็นเส้นทางการเรียนรู้ที่ดีเยี่ยม แต่ในการทำงานจริง นักพัฒนามักใช้ “Starter Theme” หรือ “Parent Theme” เป็นพื้นฐาน ตัวอย่างเช่น Theme ทางการอย่าง Underscores (_s) เป็นจุดเริ่มต้นคุณภาพสูงที่เรียบง่ายและเป็นไปตามมาตรฐานการเขียนโค้ด โดยมีโครงสร้างไฟล์พื้นฐานและฟังก์ชันที่ใช้บ่อย ๆ สร้างไว้แล้ว คุณสามารถพัฒนาตามความต้องการบนพื้นฐานนี้ได้ ซึ่งจะช่วยเพิ่มประสิทธิภาพและรับประกันคุณภาพโค้ดได้อย่างมาก

ไฟล์ functions.php ผิดพลาดจะส่งผลอะไรบ้าง?

functions.php ข้อผิดพลาดทางไวยากรณ์หรือข้อผิดพลาดร้ายแรงในไฟล์อาจทำให้เว็บไซต์ WordPress เกิด “หน้าจอขาวแห่งความตาย” (White Screen of Death) ซึ่งทั้งหน้าเว็บและส่วนหลังบ้านไม่สามารถเข้าถึงได้ เนื่องจากไฟล์นี้ถูกดำเนินการตั้งแต่เริ่มต้นโหลด Theme เมื่อเจอสถานการณ์เช่นนี้ คุณจำเป็นต้องใช้ FTP หรือตัวจัดการไฟล์ของโฮสต์ เปลี่ยนชื่อโฟลเดอร์ Theme ที่มีปัญหาหรือแทนที่ด้วย Theme ที่ทำงานปกติ (เช่น Twenty Twenty-Six) เพื่อกู้การเข้าถึงเว็บไซต์คืน จากนั้นจึงค่อยไปแก้ไขโค้ดที่ผิดพลาด

จะทำให้ธีมของฉันรองรับตัวแก้ไข Gutenberg ได้อย่างไร

เพื่อให้ Theme รองรับตัวแก้ไขแบบบล็อก Gutenberg ได้ดีขึ้น ก่อนอื่นควร functions.php ใช้ฟังก์ชัน add_theme_support( ‘editor-styles’ ) เพื่อเปิดใช้งานการรองรับสไตล์ของตัวแก้ไข จากนั้น ใช้ add_editor_style() ฟังก์ชันนี้จะนำสไตล์ชีตของธีมของคุณหรือไฟล์ CSS ที่เขียนขึ้นสำหรับตัวแก้ไขมาใช้ในตัวแก้ไขหลังบ้าน ซึ่งจะช่วยให้มั่นใจว่าสไตล์ที่ผู้ใช้เห็นขณะแก้ไขจะสอดคล้องกับการแสดงผลด้านหน้าให้มากที่สุด นอกจากนี้คุณยังสามารถเพิ่มการรองรับฟังก์ชันบล็อกต่างๆ เช่น การจัดแนวแบบกว้าง การกำหนดสีเอง เป็นต้น