راهنمای جامع توسعه افزونه وردپرس

چرا توسعه افزونه وردپرس حیاتی است؟

وردپرس به بیش از ۴۰٪ وب‌سایت‌های جهان قدرت می‌دهد و بخش عمده‌ای از انعطاف‌پذیری آن مدیون توسعه افزونه وردپرس است. افزونه‌ها بسته‌های مستقل شامل کدهای PHP، جاوا اسکریپت و سایر دارایی‌ها هستند که قابلیت‌های وردپرس را گسترش می‌دهند. این افزونه‌ها همه چیز را، از ترفندهای ساده گرفته تا ویژگی‌های پیچیده تجاری، هدایت می‌کنند. اگر شما یک توسعه‌دهنده جدید هستید، یادگیری نحوه ساخت افزونه‌ها، دروازه شما به سمت سفارشی‌سازی و مقیاس‌دهی این پلتفرم برای هر نیازی است.

توسعه افزونه وردپرس مهارتی کلیدی است که به شما امکان می‌دهد عملکرد دلخواه خود را به هسته سیستم اضافه کنید، بدون اینکه تغییرات شما در به‌روزرسانی‌های آینده از بین برود. در این راهنمای جامع، شما اصول اولیه توسعه افزونه وردپرس را می‌آموزید، یک محیط محلی را با استفاده از ابزارهای مناسب تنظیم می‌کنید و یک افزونه کاربردی به عنوان مثال می‌سازید. تا پایان این مقاله، شما با کالبد یک افزونه، نحوه عملکرد هوک‌ها (Hooks) و بهترین روش‌ها برای کدنویسی امن و قابل نگهداری آشنا خواهید شد. سفر شما در توسعه افزونه وردپرس همینجا آغاز می‌شود.

تنظیم یک محیط توسعه محلی

قبل از اینکه یک خط کد بنویسید، به یک محیط وردپرس محلی نیاز دارید. محیط محلی امکان آزمایش سریع و ایمن کدها را بدون تأثیرگذاری بر وب‌سایت زنده شما فراهم می‌کند. ابزارهایی مانند WordPress Studio سریع‌ترین راه برای شروع هستند. Studio یک ابزار منبع باز است که توسط Automattic پشتیبانی می‌شود و برای تسهیل توسعه افزونه وردپرس طراحی شده است.

گام ۱: نصب ابزار توسعه (Studio)

گام ۲: آماده‌سازی فضای کدنویسی

ساختاردهی اولین افزونه شما

هر افزونه با یک پوشه و حداقل یک فایل PHP شروع می‌شود. بیایید یک افزونه مینیمال «Hello World» بسازیم تا فرآیند ساخت در توسعه افزونه وردپرس را ساده کنیم.

سربرگ افزونه (Plugin Header)

این سربرگ اطلاعات مورد نیاز وردپرس برای شناسایی افزونه شماست:

PHP

<?php
/*
Plugin Name: Quick Reading Time
Description: Displays an estimated reading-time badge beneath post titles.
Version:     1.0
Author:      Your Name
License:     GPL-2.0+
Text Domain: quick-reading-time
*/

این بخش در واقع یک کامنت PHP است، اما وردپرس آن را اسکن می‌کند تا افزونه شما را در بخش «افزونه‌ها -> افزونه‌های نصب‌شده» لیست کند. آن را فعال کنید. هنوز هیچ اتفاقی نمی‌افتد، اما شما اولین گام در توسعه افزونه وردپرس را برداشته‌اید.

درک هوک‌ها (Hooks): Actions و Filters

افزونه‌های وردپرس از طریق هوک‌ها با رویدادهای هسته سیستم تعامل برقرار می‌کنند. این هوک‌ها قلب توسعه افزونه وردپرس هستند و به شما اجازه می‌دهند کد خود را در نقاط خاصی از چرخه عمر وردپرس اجرا کنید.

بیایید با استفاده از فیلتر the_content، یک نشان زمان مطالعه به محتوای پست‌ها اضافه کنیم:

PHP

function qrt_add_reading_time( $content ) {
    // Check if it's a single post in the main loop
    if ( ! is_singular( 'post' ) || ! in_the_loop() || ! is_main_query() ) {
        return $content; // Return content unchanged if not on a post
    }

    // ۱. Strip HTML/shortcodes, count words
    $plain   = wp_strip_all_tags(strip_shortcodes($content));
    $words   = str_word_count( $plain );

    // ۲. Estimate: 200 words per minute (WPM)
    $wpm     = (int) get_option( 'qrt_wpm', ۲۰۰ ); // Use setting or default 200
    $minutes = max( ۱, ceil( $words / $wpm ) );

    // ۳. Build the badge
    $badge = sprintf(
        '<p class="qrt-badge" aria-label="%s"><span>%s</span></p>',
        esc_attr__( 'Estimated reading time', 'quick-reading-time' ),
        esc_html( sprintf( _n( '%s min read', '%s mins read', $minutes, 'quick-reading-time' ), $minutes ) )
    );

    return $badge . $content; // Prepend badge to content
}
add_filter( 'the_content', 'qrt_add_reading_time' );

این کد عملکرد اصلی افزونه ما را ایجاد می‌کند و از مفاهیم اصلی توسعه افزونه وردپرس برای اضافه کردن محتوای سفارشی به پست‌ها استفاده می‌کند.

بارگذاری دارایی‌ها به روش وردپرس

برای استایل دادن به نشان زمان مطالعه، باید یک شیوه نامه (Stylesheet) را به روش صحیح وردپرس در صفحه بارگذاری کنیم. در توسعه افزونه وردپرس، باید از هوک wp_enqueue_scripts استفاده کنید تا مطمئن شوید فایل شما در زمان مناسب و به درستی بارگذاری می‌شود.

PHP

function qrt_enqueue_assets() {
    wp_enqueue_style(
        'qrt-style',
        plugin_dir_url( __FILE__ ) . 'style.css',
        array(),
        '۱.۰'
    );
}
add_action( 'wp_enqueue_scripts', 'qrt_enqueue_assets' );

حالا، فایل style.css را در همان پوشه افزونه ایجاد کنید تا استایل ساده‌ای به نشانک بدهید:

CSS

.qrt-badge span {
    margin: ۰ ۰ ۱rem;
    padding: ۰.۲۵rem ۰.۵rem;
    display: inline-block;
    background: #f5f5f5;
    color: #۵۵۵;
    font-size: ۰.۸۵em;
    border-radius: ۴px;
}

نکته مهم: همیشه دارایی‌ها (CSS/JS) را فقط در مواقعی که واقعاً نیاز دارید بارگذاری کنید (مثلاً فقط در قسمت فرانت‌اند یا برای انواع پست‌های خاص) تا عملکرد وب‌سایت بهبود یابد.

بخش اختیاری: اضافه کردن صفحه تنظیمات

برای اینکه سرعت متوسط خواندن توسط کاربر قابل تنظیم باشد، یک صفحه تنظیمات به افزونه اضافه می‌کنیم. این کار با استفاده از Settings API در توسعه افزونه وردپرس انجام می‌شود.

گام ۱: ثبت تنظیمات و اعتبارسنجی

این کد یک گزینه جدید به نام qrt_wpm را در پایگاه داده ثبت می‌کند. این گزینه سرعت کلمات در دقیقه (WPM) را ذخیره می‌کند و تابع qrt_sanitize_wpm آن را اعتبارسنجی می‌کند:

PHP

// Register the setting during admin_init.
function qrt_register_settings() {
    register_setting( 'qrt_settings_group', 'qrt_wpm', array(
        'type' => 'integer',
        'sanitize_callback' => 'qrt_sanitize_wpm',
        'default' => ۲۰۰,
    ) );
}
add_action( 'admin_init', 'qrt_register_settings' );

// Sanitize the WPM value.
function qrt_sanitize_wpm( $value ) {
    $value = intval($value);
    return ( $value > ۰ ) ? $value : ۲۰۰; // Must be a positive integer
}

گام ۲: اضافه کردن صفحه تنظیمات به منوی مدیریت

با استفاده از هوک admin_menu، یک لینک به صفحه تنظیمات افزونه در زیر منوی «Settings» (تنظیمات) اضافه می‌کنیم:

PHP

function qrt_register_settings_page() {
    add_options_page(
        'Quick Reading Time', // Page Title
        'Quick Reading Time', // Menu Title
        'manage_options',     // Capability
        'qrt-settings',       // Menu Slug
        'qrt_render_settings_page' // Callback function
    );
}
add_action( 'admin_menu', 'qrt_register_settings_page' );

گام ۳: رندر کردن صفحه تنظیمات

این تابع فرم ورودی را نمایش می‌دهد و از توابع Settings API برای پردازش امن داده‌ها استفاده می‌کند:

PHP

function qrt_render_settings_page() {
    if ( ! current_user_can( 'manage_options' ) ) {
        return; // Security check
    }
    ?>
    <div class="wrap">
        <h1><?php esc_html_e( 'Quick Reading Time Settings', 'quick-reading-time' ); ?></h1>
        <form method="post" action="options.php">
            <?php
            settings_fields( 'qrt_settings_group' );
            do_settings_sections( 'qrt_settings_group' );
            $wpm = get_option( 'qrt_wpm', ۲۰۰ ); // Get saved value
            ?>
            <table class="form-table" role="presentation">
                <tr>
                    <th scope="row">
                        <label for="qrt_wpm"><?php esc_html_e( 'Words Per Minute', 'quick-reading-time' ); ?></label>
                    </th>
                    <td>
                        <input name="qrt_wpm" type="number" id="qrt_wpm" value="<?php echo esc_attr( $wpm ); ?>" class="small-text" min="۱" />
                        <p class="description"><?php esc_html_e( 'Average reading speed for your audience.', 'quick-reading-time' ); ?></p>
                    </td>
                </tr>
            </table>
            <?php submit_button(); ?>
        </form>
    </div>
    <?php
}

با این تغییرات، افزونه شما اکنون یک صفحه تنظیمات کاربرپسند در بخش تنظیمات -> Quick Reading Time فراهم می‌کند و مفهوم کامل توسعه افزونه وردپرس را به نمایش می‌گذارد.

بهترین روش‌ها در توسعه افزونه وردپرس

ساخت یک افزونه فقط به کارکرد آن محدود نمی‌شود، بلکه باید کدی قوی، امن و قابل نگهداری باشد. رعایت بهترین روش‌ها در توسعه افزونه وردپرس ضروری است.

نتیجه‌گیری و گام‌های بعدی

شما اکنون یک افزونه کاری دارید که سه هوک «طلایی» را نمایش می‌دهد: the_content (برای درج محتوا)، wp_enqueue_scripts (برای بارگذاری استایل‌ها) و admin_menu (برای اضافه کردن تنظیمات).

توسعه افزونه وردپرس یک سفر است. گام بعدی برای شما می‌تواند افزودن انواع پست سفارشی (initنقاط پایانی REST API (rest_api_init) یا بلاک‌های گوتنبرگ (register_block_type) باشد. مدل ذهنی همیشه یکسان است: هوک درست را پیدا کنید، تابع فراخوانی (callback) را بنویسید و اجازه دهید وردپرس آن را اجرا کند.

با تمرین، جهش از «ای کاش وردپرس می‌توانست…» به «وردپرس انجام می‌دهد» برای شما تبدیل به یک طبیعت ثانویه خواهد شد. به کاوش در توسعه افزونه وردپرس ادامه دهید و از ساختن قابلیت‌های جدید برای وب‌سایت‌ها لذت ببرید.

خروج از نسخه موبایل