Hooks و Filters وردپرس: راهنمای فنی توسعهپذیری و کدنویسی تمیز
آنچه در این مقاله میخوانید
- Hooks و Filters وردپرس: راهنمای فنی توسعهپذیری و کدنویسی تمیز
- Hooks وردپرس چیست؟ (کالبدشکافی فنی)
- دو نوع قلاب: تفاوت Action و Filter
- بخش اول: آموزش Action Hooks (قلابهای عملیاتی)
- توابع کلیدی Actions: `do_action` و `add_action`
- نمونه کدهای عملی `add_action`
- Action Hooks و تاثیر بر عملکرد (TTFB و CWV)
- بخش دوم: آموزش Filter Hooks (قلابهای فیلتر)
- توابع کلیدی Filters: `apply_filters` و `add_filter`
- نمونه کدهای عملی `add_filter`
- مفاهیم پیشرفته Hooks: اولویت (Priority) و پارامترها (Arguments)
- ۱. اولویت (Priority): مدیریت ترتیب اجرا
- ۲. پارامترهای پذیرفتهشده (Accepted Arguments)
- نتیجهگیری: Hooks، زبان توسعه تمیز وردپرس

برای «سارا»، مدیر بازاریابی فنی، این یک سوال اساسی است: وردپرس چگونه کار میکند؟ چگونه یک پلاگین سئو میتواند به طور «جادویی» فیلدهای متا را به ویرایشگر پست اضافه کند؟ چگونه یک قالب، منوهای سفارشی را ثبت میکند یا اسکریپتهای خاصی را در هدر بارگذاری میکند؟ پاسخ «جادو» نیست؛ پاسخ، یکی از قدرتمندترین و در عین حال درکنشدهترین مفاهیم هسته وردپرس است: Hooks و Filters وردپرس.
سیستم «قلاب» (Hook) ستون فقرات کل پلتفرم وردپرس است. این چیزی است که وردپرس را از یک وبلاگ ساده به یک سیستم مدیریت محتوای (CMS) کاملاً توسعهپذیر تبدیل میکند. برای «سارا»، درک تفاوت Action و Filter فقط یک دانش فنی جالب نیست؛ این یک ضرورت برای توسعه قالب وردپرس حرفهای، کدنویسی تمیز وردپرس، و عیبیابی عملکرد سایت است.
این مقاله یک راهنمای فنی عمیق برای کالبدشکافی Hooks وردپرس چیست، چگونه قلابهای عملیاتی (Action Hooks) از قلابهای فیلتر (Filter Hooks) متمایز میشوند، و چگونه استفاده صحیح از add_action و add_filter برای کدنویسی وردپرس امن و بهینه حیاتی است.
Hooks وردپرس چیست؟ (کالبدشکافی فنی)
Hooks (قلابها) در وردپرس، نقاط اتصال یا «رویدادهایی» (Events) هستند که در سراسر کد هسته وردپرس، پلاگینها و قالبها قرار داده شدهاند. این قلابها به توسعهدهندگان اجازه میدهند تا توابع (Functions) سفارشی خود را در نقاط بسیار خاصی از فرآیند اجرای وردپرس «آویزان» کنند.
یک تشبیه ساده: هسته وردپرس را به عنوان یک خط مونتاژ کارخانه در نظر بگیرید. این خط مونتاژ (مثلاً فرآیند بارگذاری یک صفحه) مراحل مشخصی دارد: «شروع بارگذاری»، «اتصال به دیتابیس»، «واکشی پست»، «رندر هدر»، «رندر محتوا»، «رندر فوتر».
Hooks وردپرس مانند «پریزهای برق» در طول این خط مونتاژ هستند. وردپرس در هر مرحله کلیدی اعلام میکند: “من در حال رندر کردن هدر هستم (wp_head). آیا کسی میخواهد چیزی به اینجا وصل کند؟” یا “من در حال واکشی عنوان پست (the_title) هستم. آیا کسی میخواهد آن را تغییر دهد؟”
این سیستم به «سارا» اجازه میدهد تا عملکرد وردپرس را به طور اساسی تغییر دهد *بدون اینکه هرگز یک خط از کد هسته وردپرس را ویرایش کند*. این، قانون شماره یک کدنویسی تمیز وردپرس و امنیت قالب وردپرس است: هرگز فایلهای هسته (Core Files) را ویرایش نکنید.
دو نوع قلاب: تفاوت Action و Filter
سیستم Hooks و Filters وردپرس به دو دسته کاملاً مجزا با اهداف متفاوت تقسیم میشود. درک این تفاوت، حیاتیترین بخش آموزش Action Hooks و آموزش Filter Hooks است.
- Action Hooks (قلابهای عملیاتی):
- هدف: «انجام دادن» یک کار (Do Something).
- عملکرد: به شما اجازه میدهد تا یک تابع سفارشی را در یک نقطه خاص اجرا کنید. این توابع معمولاً چیزی را «خروجی» (Echo) میدهند، چیزی را در دیتابیس ثبت میکنند، یا یک اسکریپت را فراخوانی میکنند.
- بازگشت داده: توابع Action *هیچ چیزی را برنمیگردانند* (Return نمیکنند). آنها فقط اجرا میشوند.
- Filter Hooks (قلابهای فیلتر):
- هدف: «تغییر دادن» یک داده (Change Something).
- عملکرد: به شما اجازه میدهد تا یک قطعه داده (مانند متن عنوان پست، محتوای پست، یا یک کلاس CSS) را در میانه راه رهگیری کنید، آن را تغییر دهید، و سپس آن را بازگردانید.
- بازگشت داده: توابع Filter *باید* (Must) داده اصلاحشده (یا اصلی) را
returnکنند. اگر شما دادهای را برنگردانید، آن داده «ناپدید» میشود (مثلاً تمام عناوین پستهای شما خالی میشوند!).
بخش اول: آموزش Action Hooks (قلابهای عملیاتی)
Actions همه چیز درباره «اجرا» هستند. اینها اسبهای کاری کدنویسی وردپرس هستند که وظایف را انجام میدهند.
توابع کلیدی Actions: `do_action` و `add_action`
do_action( 'hook_name' ): این تابع «قلاب» را ایجاد میکند. این کد در *هسته* وردپرس (یا یک پلاگین) قرار دارد. این همان «پریز برق» روی دیوار است. مثال: وردپرس تابعdo_action( 'wp_head' )را در فایلheader.phpخود اجرا میکند.add_action( 'hook_name', 'your_function_name' ): این تابعی است که «شما» در فایلfunctions.phpقالب خود مینویسید. این «دوشاخه» شماست. این به وردپرس میگوید: “هر وقت به قلابwp_headرسیدی، لطفاً تابع من به نامmy_custom_functionرا اجرا کن.”
نمونه کدهای عملی `add_action`
این کدها معمولاً در فایل functions.php قالب شما قرار میگیرند، که بخشی از فرآیند ساخت قالب وردپرس از صفر است.
مثال ۱: فراخوانی صحیح CSS و JS (استاندارد طلایی)
یک مبتدی ممکن است تگهای <link> و <script> را مستقیماً در header.php هارد-کد کند. این یک عمل «کثیف» است. روش صحیح استفاده از قلاب wp_enqueue_scripts است.
/**
* فراخوانی صحیح اسکریپتها و استایلهای قالب
* این تابع به قلاب 'wp_enqueue_scripts' متصل میشود.
*/
function adrenaliz_theme_assets() {
// فراخوانی فایل CSS اصلی
wp_enqueue_style(
'adrenaliz-main-style',
get_stylesheet_uri(),
array(),
'1.0.0'
);
// فراخوانی فایل JS اصلی
wp_enqueue_script(
'adrenaliz-main-script',
get_template_directory_uri() . '/js/main.js',
array('jquery'), // به وردپرس میگوید که این اسکریپت به jQuery وابسته است
'1.0.0',
true // true = این اسکریپت را در فوتر بارگذاری کن (بهترین تمرین برای عملکرد)
);
}
// اتصال تابع ما به قلاب وردپرس
add_action( 'wp_enqueue_scripts', 'adrenaliz_theme_assets' );
چرا این بهتر است؟ زیرا به وردپرس اجازه میدهد تا وابستگیها را مدیریت کند (مثلاً jQuery را فقط یک بار بارگذاری کند) و به پلاگینهای دیگر اجازه میدهد تا در صورت نیاز، این اسکریپتها را تغییر دهند یا حذف کنند. این اساس کدنویسی تمیز وردپرس است.
مثال ۲: افزودن کدهای ردیابی به هدر و فوتر
شما هرگز نباید header.php را برای افزودن کد Google Tag Manager ویرایش کنید. از قلابهای wp_head و wp_footer استفاده کنید.
/**
* افزودن کد GTM به هدر
*/
function adrenaliz_gtm_head() {
?>
<!-- Google Tag Manager Script -->
<script>... (کد GTM شما در اینجا) ...</script>
<!-- End Google Tag Manager -->
<?php
}
add_action( 'wp_head', 'adrenaliz_gtm_head', 1 ); // اولویت 1 آن را در بالاترین نقطه هدر اجرا میکند
/**
* افزودن GTM (noscript) به فوتر
*/
function adrenaliz_gtm_body() {
?>
<!-- Google Tag Manager (noscript) -->
<noscript>... (کد noscript شما) ...</noscript>
<!-- End Google Tag Manager (noscript) -->
<?php
}
// قلاب wp_body_open بلافاصله بعد از تگ <body> اجرا میشود
add_action( 'wp_body_open', 'adrenaliz_gtm_body', 1 );
Action Hooks و تاثیر بر عملکرد (TTFB و CWV)
Hooks و Filters وردپرس رایگان نیستند. هر تابعی که شما به یک قلاب اضافه میکنید، به «زمان پردازش سرور» (Server Processing Time) اضافه میکند. این مستقیماً بر TTFB (Time to First Byte) تأثیر میگذارد.
اگر «سارا» تابعی را به قلاب init (که در هر بارگذاری صفحه اجرا میشود) اضافه کند که یک کوئری SQL بسیار سنگین و بهینهنشده را اجرا میکند، او به تنهایی میتواند TTFB سایت را ۱ تا ۲ ثانیه افزایش دهد. این به نوبه خود، کل زنجیره بهینهسازی Core Web Vitals (مخصوصاً LCP) را به تأخیر میاندازد. کدنویسی وردپرس هوشمندانه یعنی آگاهی از «هزینه» هر add_action.
بخش دوم: آموزش Filter Hooks (قلابهای فیلتر)
Filters همه چیز درباره «تغییر» هستند. آنها دادهها را میگیرند، آنها را پردازش میکنند و برمیگردانند. اینها ابزارهای جراحی دقیق شما برای تغییر خروجی وردپرس هستند.

توابع کلیدی Filters: `apply_filters` و `add_filter`
apply_filters( 'filter_name', $variable_to_filter ): این تابع «قلاب فیلتر» را ایجاد میکند. این کد در *هسته* وردپرس قرار دارد. وردپرس میگوید: “من این متغیر ($variable_to_filter) را دارم. آیا کسی میخواهد آن را قبل از استفاده، تغییر دهد؟”add_filter( 'filter_name', 'your_function_name' ): این کد «شما» درfunctions.phpاست. این به وردپرس میگوید: “بله! وقتی به فیلترfilter_nameرسیدی، آن متغیر را به تابع من (your_function_name) بده. من آن را تغییر میدهم و به تو *برمیگردانم* (return).”
قانون طلایی Filter Hooks: همیشه داده را برگردانید!
این یک تله رایج برای مبتدیان است. تابع فیلتر شما *باید* همیشه یک مقدار را
returnکند. اگر شما فراموش کنید کهreturn $variable;را در انتهای تابع خود بنویسید، دادهها در تابع شما «میمیرند». نتیجه: به جای عنوان پست، یک فضای خالی دریافت میکنید. تفاوت Action و Filter در همین کلمهreturnاست.
نمونه کدهای عملی `add_filter`
این نمونهها قدرت واقعی آموزش Filter Hooks را نشان میدهند.

مثال ۱: تغییر طول خلاصه (Excerpt Length)
به طور پیشفرض، the_excerpt() وردپرس متن را به ۵۵ کلمه محدود میکند. اگر «سارا» بخواهد آن را به ۲۰ کلمه تغییر دهد، نیازی به هک کردن هسته نیست. او از فیلتر excerpt_length استفاده میکند.
/**
* تغییر طول خلاصه پیشفرض وردپرس
* به قلاب فیلتر 'excerpt_length' متصل میشود.
*/
function adrenaliz_custom_excerpt_length( $length ) {
// مقدار پیشفرض (55) را نادیده بگیر و عدد جدید را برگردان
return 20;
}
add_filter( 'excerpt_length', 'adrenaliz_custom_excerpt_length' );
مثال ۲: افزودن کلاس CSS سفارشی به بدنه (Body Class)
این یک تکنیک UX/UI بسیار قدرتمند است. فرض کنید «سارا» میخواهد اگر کاربر در حال مشاهده یک پست تکی است، یک کلاس CSS خاص به تگ <body> اضافه کند تا بتواند استایلهای منحصربهفردی اعمال کند.
/**
* افزودن کلاس سفارشی به تگ <body>
* به قلاب فیلتر 'body_class' متصل میشود.
*/
function adrenaliz_custom_body_class( $classes ) {
// $classes یک آرایه (array) از تمام کلاسهای موجود است
if ( is_single() ) {
// اگر این یک پست تکی است، کلاس ما را به آرایه اضافه کن
$classes[] = 'adrenaliz-single-post';
}
// آرایه کامل و اصلاحشده کلاسها را برگردان
return $classes;
}
add_filter( 'body_class', 'adrenaliz_custom_body_class' );
مفاهیم پیشرفته Hooks: اولویت (Priority) و پارامترها (Arguments)
برای تسلط واقعی بر کدنویسی وردپرس، «سارا» باید دو پارامتر نهایی را در add_action و add_filter درک کند.
ساختار کامل این توابع به این شکل است:add_action( $hook_name, $your_function, $priority, $accepted_args );add_filter( $hook_name, $your_function, $priority, $accepted_args );
۱. اولویت (Priority): مدیریت ترتیب اجرا
$priority(اولویت) یک عدد صحیح است که ترتیب اجرای توابع متصل به یک قلاب را مشخص میکند.- مقدار پیشفرض آن
10است. - اعداد کمتر = اجرای زودتر. اگر شما
add_action( 'wp_head', 'my_func', 1 );را تنظیم کنید، تابع شما احتمالاً اولین چیزی است که در هدر اجرا میشود. - اعداد بیشتر = اجرای دیرتر. اگر
add_action( 'wp_head', 'my_func', 99 );را تنظیم کنید، تابع شما احتمالاً آخرین چیزی است که اجرا میشود (مثلاً بعد از تمام اسکریپتهای پلاگینها).
این برای مدیریت وابستگیها و اطمینان از اینکه کد شما در زمان مناسب اجرا میشود، حیاتی است.
۲. پارامترهای پذیرفتهشده (Accepted Arguments)
$accepted_args(آرگومانهای پذیرفتهشده) به وردپرس میگوید که تابع شما «انتظار دارد» چند متغیر (پارامتر) را از قلاب دریافت کند.- مقدار پیشفرض آن
1است (که در فیلترها، همان متغیر اصلی است که باید تغییر کند). - اما بسیاری از قلابهای وردپرس، اطلاعات زمینهای (Contextual) بیشتری را ارسال میکنند.
مثال پیشرفته فیلتر:
قلاب the_title در واقع دو پارامتر ارسال میکند: apply_filters( 'the_title', $title, $id ); (عنوان پست، و شناسه پست).
اگر «سارا» بخواهد عنوان را *فقط* برای پست با ID 42 تغییر دهد:
/**
* تغییر عنوان فقط برای یک پست خاص
*/
function adrenaliz_conditional_title( $title, $id ) {
if ( $id == 42 ) {
// فقط اگر ID پست 42 باشد، عنوان را تغییر بده
return 'این عنوان ویژه است: ' . $title;
}
// در غیر این صورت، عنوان اصلی را دستنخورده برگردان
return $title;
}
// **نکات کلیدی در اینجا:**
// 1. اولویت 10 است (پیشفرض).
// 2. ما به وردپرس میگوییم که تابع ما 2 آرگومان میپذیرد.
add_filter( 'the_title', 'adrenaliz_conditional_title', 10, 2 );
عدم تنظیم پارامتر $accepted_args به 2 باعث میشود که $id در تابع شما null باشد و کد کار نکند. این تفاوت فنی، مرز بین کدنویسی وردپرس آماتور و حرفهای را مشخص میکند.
نتیجهگیری: Hooks، زبان توسعه تمیز وردپرس
Hooks و Filters وردپرس، الفبای توسعه قالب وردپرس هستند. آنها به «سارا» و تیمش اجازه میدهند تا بدون دستکاری هسته، تقریباً هر جنبهای از وردپرس را گسترش دهند، تغییر دهند و کنترل کنند.
درک تفاوت Action و Filter (انجام دادن در مقابل تغییر دادن) و تسلط بر توابع add_action و add_filter (همراه با اولویتها و پارامترها)، به شما این امکان را میدهد که:
- قالبهای کدنویسی تمیز وردپرس بسازید که سریع، قابل نگهداری و بهینه باشند.
- ویژگیهای امنیتی سفارشی را طبق استانداردهای امنیتی وردپرس پیادهسازی کنید.
- از عملکرد سایت خود در برابر کدهای سنگین محافظت کنید و Core Web Vitals را بهینه نگه دارید.
در نهایت، Hooks وردپرس چیست؟ آنها زبان رسمی مکالمه با هسته وردپرس هستند. یادگیری این زبان، اولین قدم برای اثبات E-A-T فنی در اکوسیستم وردپرس است.

