ویژگی تصویر

تابع apply_filters در وردپرس

  /  وردپرس   /  تابع apply_filters در وردپرس
بنر تبلیغاتی الف
wp - wordpress - وردپرس

تابع apply_filters() یکی از مهم‌ترین توابع در سیستم هوک (Hook System) وردپرس است که به توسعه‌دهندگان اجازه می‌دهد داده‌ها را قبل از نمایش یا استفاده، فیلتر یا تغییر دهند. این تابع در واقع داده‌ای را از یک فیلتر عبور می‌دهد و تمام توابعی که با استفاده از add_filter() به آن متصل شده‌اند، می‌توانند آن داده را تغییر دهند.

مفهوم کلی فیلترها (Filters) در وردپرس

در وردپرس دو نوع هوک اصلی وجود دارد:

  • Action Hooks: برای اجرای عملیات خاص در زمان مشخصی (بدون بازگرداندن مقدار)
  • Filter Hooks: برای تغییر مقدار داده‌ها قبل از استفاده یا نمایش

تابع apply_filters() در نوع دوم (Filter Hooks) استفاده می‌شود و وظیفه آن عبور دادن داده از مجموعه‌ای از فیلترها است تا در نهایت نسخه نهایی و اصلاح‌شده آن بازگردانده شود.

ساختار و نحوه استفاده از تابع apply_filters()

apply_filters( string $hook_name, mixed $value, mixed ...$args );

توضیح پارامترها:

پارامترتوضیح
$hook_nameنام فیلتر (Hook) که می‌خواهید اعمال شود. باید با نامی که در تابع add_filter() استفاده می‌شود یکسان باشد.
$valueمقداری که قرار است از فیلتر عبور کند و ممکن است تغییر یابد.
$argsآرگومان‌های اضافی که می‌توانند به توابع فیلتر ارسال شوند (اختیاری).

مثال ساده از استفاده تابع apply_filters()

function my_custom_title( $title ) {
    return '🔥 ' . $title . ' 🔥';
}

add_filter( 'the_title', 'my_custom_title' );

$title = apply_filters( 'the_title', 'Hello World' );
echo $title;

در این مثال، فیلتر the_title با تابع my_custom_title() متصل شده است. هنگامی که apply_filters() اجرا می‌شود، رشته‌ی «Hello World» از طریق فیلتر عبور می‌کند و در نتیجه خروجی به صورت 🔥 Hello World 🔥 نمایش داده می‌شود.

توضیح گام به گام عملکرد apply_filters()

  1. تابع apply_filters() اجرا می‌شود و مقدار اولیه ($value) را دریافت می‌کند.
  2. وردپرس بررسی می‌کند که آیا فیلترهایی با نام $hook_name ثبت شده‌اند یا خیر.
  3. اگر فیلترهایی وجود داشته باشند، به ترتیب اولویت اجرا می‌شوند و هرکدام می‌توانند مقدار را تغییر دهند.
  4. در نهایت مقدار تغییر یافته بازگردانده می‌شود.

نکته مهم:

اگر هیچ فیلتری ثبت نشده باشد، مقدار اولیه بدون تغییر بازگردانده می‌شود. این باعث می‌شود که apply_filters() همیشه ایمن و قابل استفاده در هر شرایطی باشد.

مثال پیشرفته‌تر با چند فیلتر

function add_prefix( $text ) {
    return 'Prefix: ' . $text;
}

function add_suffix( $text ) {
    return $text . ' :Suffix';
}

add_filter( 'custom_text', 'add_prefix', 10 );
add_filter( 'custom_text', 'add_suffix', 20 );

$text = apply_filters( 'custom_text', 'Main Content' );
echo $text;

در این مثال، دو فیلتر با اولویت‌های مختلف روی یک داده اعمال می‌شوند. ابتدا add_prefix() اجرا می‌شود و متن را به «Prefix: Main Content» تبدیل می‌کند. سپس add_suffix() اجرا شده و نتیجه نهایی می‌شود:

Prefix: Main Content :Suffix

نقش اولویت (Priority) در ترتیب اجرای فیلترها

در تابع add_filter() سومین پارامتر عددی مشخص‌کننده‌ی اولویت اجرا است. مقدار کمتر به معنی اجرای زودتر است. مقدار پیش‌فرض برابر با 10 است. با کنترل این عدد می‌توانید ترتیب اجرای توابع فیلتر را تعیین کنید.

ارسال چند پارامتر به فیلتر

function change_price( $price, $tax ) {
    return $price + $tax;
}

add_filter( 'calculate_price', 'change_price', 10, 2 );

$final_price = apply_filters( 'calculate_price', 100, 20 );
echo $final_price;

در این مثال، تابع change_price() دو پارامتر دریافت می‌کند: قیمت اصلی و مالیات. هنگام اجرای apply_filters() این دو مقدار ارسال می‌شوند و خروجی برابر با 120 خواهد بود.

کاربرد تابع apply_filters() در توسعه افزونه‌ها و قالب‌ها

  • سفارشی‌سازی متن‌ها: می‌توانید عبارات یا محتواها را قبل از نمایش تغییر دهید.
  • تغییر تنظیمات پیش‌فرض: مقدار متغیرهای پیکربندی را با فیلترها قابل ویرایش کنید.
  • توسعه API داخلی: ایجاد فیلترهای اختصاصی برای افزونه‌ها به منظور گسترش‌پذیری.
  • کنترل داده‌ها قبل از ذخیره در دیتابیس: می‌توان داده‌ها را فیلتر و تمیز کرد تا امنیت بالا برود.

نمونه کاربرد واقعی در وردپرس

$content = apply_filters( 'the_content', get_the_content() );

در هسته وردپرس، تابع بالا برای نمایش محتوای نوشته استفاده می‌شود. این فیلتر به توسعه‌دهندگان اجازه می‌دهد قبل از نمایش محتوا، آن را ویرایش یا پردازش کنند؛ مانند افزودن تبلیغات، لینک‌ها یا تغییرات ظاهری.

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

function my_plugin_custom_data( $data ) {
    return strtoupper( $data );
}

add_filter( 'myplugin_filter_data', 'my_plugin_custom_data' );

$value = apply_filters( 'myplugin_filter_data', 'hello world' );
echo $value;

در این مثال، فیلتر myplugin_filter_data در افزونه ساخته شده و مقدار ورودی را به حروف بزرگ تبدیل می‌کند. این روش به دیگر توسعه‌دهندگان اجازه می‌دهد با استفاده از همان نام فیلتر، تغییرات خود را نیز اضافه کنند.

بهترین روش‌ها (Best Practices)

  • همیشه نام فیلترها را یکتا و معنی‌دار انتخاب کنید (مثلاً mytheme_header_text به جای header_text).
  • از ارسال پارامترهای زیاد در فیلترها خودداری کنید تا کد قابل نگهداری باشد.
  • اگر داده حساس یا امنیتی دارید، قبل از بازگرداندن از فیلتر، آن را اعتبارسنجی کنید.
  • همیشه مقدار بازگشتی فیلتر را به عنوان خروجی استفاده کنید و نه مستقیماً echo داخل تابع فیلتر.

مقایسه apply_filters() با do_action()

ویژگیapply_filters()do_action()
هدفتغییر یا اصلاح دادهاجرای عملیات بدون بازگرداندن مقدار
خروجیمقدار اصلاح‌شده را برمی‌گرداندخروجی ندارد (void)
مناسب برایفیلتر کردن داده‌ها (متن، مقدار، تنظیمات و…)اجرای رویدادها (مانند بارگذاری قالب، ذخیره پست و…)

جمع‌بندی

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

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: