وردپرس محبوب ترین سیستم مدیریت محتوا (CMS) در جهان است که سهم بازار آن بیش از 60 درصد است.
یک انجمن بزرگ پشتیب، و تعدادی افزونه رایگان موجود، ساخت یک وبسایت با وردپرس (WP) را مقرون به صرفه میسازد، و نقش کلیدی در این که چرا سهم آن در بازار بسیار زیاد است، دارد.
با این حال، همانطور که می د،د، نصب افزونه ها هزینه دارد.
آنها اغلب ممکن است نمرات Core Web Vitals شما را کاهش دهند. برای مثال، ممکن است فایلهای CSS یا JS غیرضروری را در هر صفحهای که به آنها نیازی ندارند، بارگذاری کنند.
برای رفع آن، باید یک برنامه نویس استخدام کنید تا این کار را برای شما انجام دهد، یک افزونه ممتاز ب،ید، یا شاید یک مسیر یادگیری کوچک را طی کنید و خودتان این کار را انجام دهید.
شما همچنین می تو،د ،یبی شوید و برخی از بخش های مشکلات خود را با کدنویسی سفارشی و بخش های دیگر را با استفاده از افزونه ها حل کنید.
هدف این مقاله کمک به شما در مسیر یادگیری است و ما به شما در مورد نیازترین قلاب های وردپرس برای کمک به بهبود سئوی فنی وب سایت خود کمک می کنیم.
هوک وردپرس چیست؟
قلابهای وردپرس ویژگیهای کلیدی در WP هستند که به توسعهدهندگان اجازه میدهند تا عملکرد CMS را بدون نیاز به تغییر فایلهای اصلی WP گسترش دهند – بهروزرس، تمها یا افزونهها را بدون ش،تن تغییرات سفارشی آسانتر میکند.
آنها یک راه قدرتمند برای توسعه دهندگان ارائه می کنند تا عملکرد وردپرس را گسترش دهند و تغییرات سفارشی در سایت های خود ایجاد کنند.
قلاب فیلتر چیست؟
تابع فیلتر قلاب برای اصلاح ،وجی تابع قبل از بازگشت استفاده می شود. به ،وان مثال، می تو،د با استفاده از عبارت، ،وان صفحه را با نام وبلاگ خود ،د کنید wp_،le قلاب فیلتر
اکشن هوک چیست؟
Action Hook به برنامه نویسان اجازه می دهد تا اقدامات خاصی را در یک نقطه خاص از اجرای WP Core، افزونه ها یا تم ها انجام دهند، مانند زم، که یک پست منتشر می شود یا فایل های JS و CSS بارگذاری می شوند.
با یادگیری چند قلاب یا فیلتر اصلی، می تو،د طیف گسترده ای از وظایف را بدون نیاز به استخدام توسعه دهندگان انجام دهید.
قلاب های زیر را مرور خواهیم کرد:
- wp_enqueue_scripts
- wp_head
- script_loader_tag
- template_redirect
- wp_headers
wp_enqueue_scripts
این دقیقا همان قلابی است که برای حذف فایلهای اضافی CSS یا JS از بارگذاری در صفحاتی که نیازی به آنها نیست، استفاده میکنید.
به ،وان مثال، رایگان محبوب فرم تماس 7 افزونه که بیش از 5 میلیون نصب دارد، فایلهای CSS و JS را در همه صفحات بارگیری میکند – در حالی که برای بارگیری در جایی که فرم تماس وجود دارد به آن نیاز دارید.
برای حذف فایلهای CF7 CSS و JS در صفحاتی غیر از صفحه تماس، میتو،د از قطعه کد زیر استفاده کنید.
function my_dequeue_script(){ //check if page slug isn't our contact page, alternatively, you can use is_page(25) with page ID, or if it is a post page is_single('my-post') if ( !is_page('contact') ) { wp_dequeue_script('google-recaptcha'); wp_dequeue_script('wpcf7-recaptcha'); wp_dequeue_script('contact-form-7'); wp_dequeue_style('contact-form-7'); } } add_action('wp_enqueue_scripts', 'my_dequeue_script', 99 );
چند نکته کلیدی وجود دارد؛ اولویت اکشن هوک روی 99 تنظیم شده است تا اطمینان حاصل شود که اصلاحات ما آ،ین بار در صف اجرا می شوند.
اگر آن را مثلاً روی 10 تنظیم کنید، کار نمیکند زیرا تابع صفبندی CF7 از اولویت 20 استفاده میکند. بنابراین برای اطمینان از آ،ین اجرا و تأثیرگذاری، اولویت را به اندازه کافی بزرگ تنظیم کنید.
همچنین، در کد، از شناسه آرگومان تابع “contact-form-7” استفاده کردیم. ممکن است تعجب کنید که چگونه آن را پیدا کردم.
این بسیار ساده و شهودی است. فقط از ابزار بازرسی ،صر مرورگر خود استفاده کنید و ویژگی id تگ های پیوند یا اسکریپت را بررسی کنید.
-
تصویر از نویسنده، فوریه 2023
میتو،د کد منبع وبسایت خود را با استفاده از ،صر بازرسی بررسی کنید و هر فایل JS یا CSS را در جایی که نیازی ندارید، شروع کنید.
wp_head
این اکشن هوک برای افزودن هرگونه منبع JS، فایل CSS یا متا تگ در بخش
صفحه وب استفاده می شود.با استفاده از این قلاب، می تو،د منابع پیش بارگذاری شده را در ،مت head بارگذاری کنید، که می تواند امتیاز LCP شما را بهبود بخشد.
مثلا، پیش بارگیری فونت، که یکی از توصیه های Google است، یا آرم و تصاویر برجسته در صفحات مقاله، همیشه در بالای صفحه بارگیری می شوند – و برای بهبود LCP باید آنها را از قبل بارگذاری کنید.
برای آن، از قطعه کد زیر استفاده کنید.
function my_preload() { ?> <!-- Google Fonts --> <link rel="preconnect" href=" crossorigin> <link rel="preload" as="style" href=" <link rel="preload" as="image" href=" <?php if( has_post_thumbnail() ): // check if article has featured image?> <!-- Featured Image --> <?php // $featured_image = str_ireplace(array( '.png', '.jpg', '.jpeg'), '.webp', $featured_image ); // enable this if you have webp images. ?> <?php $featured_image = get_the_post_thumbnail_url( get_the_ID(), 'full' ); ?> <link rel="preload" as="image" href="<?php ec، $featured_image;?>"/> <?php endif; } add_action('wp_head', 'my_preload', 3 );
دو خط اول برای بارگذاری فونت های گوگل از قبل است، سپس لوگو را از قبل بارگذاری می کنیم و بررسی می کنیم که آیا مقاله دارای تصویر برجسته است یا خیر، سپس تصویر برجسته را از قبل بارگذاری می کنیم.
به ،وان یک یادداشت اضافی، موضوع یا سایت شما ممکن است تصاویر webp را فعال کرده باشد. در این صورت، باید نسخه webp آنها را از قبل بارگذاری کنید.
script_loader_tag
شما در مورد منابع مسدودکننده رندر زیاد شنیده اید که می توانند با به تعویق انداختن یا ناهمگام بارگذاری بر،ب های جاوا اسکریپت رفع شوند. برای بهبود FCP و LCP حیاتی است.
این عمل فیلتر برای فیلتر ، ،وجی HTML تگهای اسکریپت استفاده میشود و شما دقیقاً به این فیلتر برای همگامسازی یا به تعویق انداختن بارگذاری تم یا فایلهای JS/CSS افزونه خود نیاز دارید.
function my_defer_async_load( $tag, $handle ) { // async loading scripts handles go here as an array $async_handles = array('wpcf7-recaptcha', 'another-plugin-script'); // defer loading scripts handles go here as an array $defer_handles = array('contact-form-7', 'any-theme-script'); if( in_array( $handle, $async_handles) ){ return str_replace( ' src', ' async src', $tag ); } if( in_array( $handle, $defer_handles ) ){ return str_replace( ' src', ' defer="defer" src', $tag ); } return $tag; } add_filter('script_loader_tag', 'my_defer_async_load', 10, 2);
این فیلتر دو آرگومان را می پذیرد: تگ HTML و دسته اسکریپت که در بالا هنگام بررسی از طریق ،صر بازرسی به آنها اشاره کردم.
میتو،د از دسته برای تصمیمگیری برای بارگیری ناهمگام یا به تعویق انداختن اسکریپت استفاده کنید.
پس از به تعویق انداختن یا عدم همگام سازی بارگذاری، همیشه از طریق کنسول مرورگر بررسی کنید که آیا خطاهای JS دارید. اگر خطاهای JS را مشاهده کردید، ممکن است به یک توسعه دهنده نیاز داشته باشید که به شما کمک کند، زیرا رفع آنها ممکن است ساده نباشد.
template_redirect
این اکشن هوک قبل از تعیین الگوی بارگیری فراخو، می شود. می تو،د از آن برای تغییر کد وضعیت HTTP پاسخ استفاده کنید.
برای مثال، ممکن است به صفحات درخواست جستجوی داخلی خود، بک لینک های اسپم حاوی کاراکترهای عجیب و/یا ال،ای رایج داشته باشید.
در ژورنال موتور جستجو، ما به داشتن بک لینک های اسپم که به صفحات جستجوی داخلی ما که به زبان کره ای هستند، عادت کرده ایم – و از لاگ های سرور خود دریافتیم که ربات گوگل به شدت در حال ،یدن آنها بوده است.
کد پاسخ پیشفرض وردپرس 404 یافت نشد، اما بهتر است 410 را وارد کنید تا به گوگل بگویید برای همیشه از بین رفتهاند، بنابراین ،یدن آنها را متوقف میکند.
function my_410_function(){ if( is_search() ) { $kw = $_GET['s']; // check if the string contains Korean characters if (preg_match('/[\x{AC00}-\x{D7AF}]+/u', $kw)) { status_header(410, 'Not Found'); } }// end of is_search } add_action( 'template_redirect', 'my_410_function', 10 );
در مورد ما، ما می د،م که محتوای کره ای نداریم، به همین دلیل شرایط خود را اینگونه تنظیم کردیم.
اما ممکن است محتوای بین المللی به زبان کره ای داشته باشید و شرایط ممکن است متفاوت باشد.
به طور کلی، برای غیر برنامه نویسان، ChatGPT یک ابزار عالی برای ایجاد شرایط با استفاده از یک عبارت منظم است، که می تو،د از آن برای ایجاد یک شرط if/else بر اساس الگوی هر،مه خود از GSC استفاده کنید.
wp_headers
این اکشن هوک برای اصلاح هدرهای HTTP وردپرس استفاده می شود.
شما می تو،د از این قلاب برای اضافه ، هدرهای امنیتی به هدرهای HTTP پاسخ وب سایت خود استفاده کنید.
function my_headers(){ $headers['content-security-policy'] = 'upgrade-insecure-requests'; $headers['strict-transport-security'] = 'max-age=31536000; preload'; $headers['X-Content-Type-Options'] = 'nosniff'; $headers['X-XSS-Protection'] = '1; mode=block'; $headers['x-frame-options'] = 'SAMEORIGIN'; $headers['Referrer-Policy'] = 'strict-origin-when-cross-origin'; $headers['Link'] = '< rel=preload; as=image'; $headers['Link'] = '< rel=preconnect; crossorigin'; $headers['Link'] = '</wp-content/uploads/themes/yourtheme/images/logo.webp>; rel=preload; as=image'; return $headers; } add_filter( 'wp_headers', 'my_headers', 100 );
در کنار هدرهای امنیتی، میتو،د تگهای «پیوند» (به تعداد دلخواه) را برای اتصال یا بارگذاری اولیه هر منبعی اضافه کنید.
اساسا، این یک روش جایگزین برای پیش بارگذاری است که در بالا توضیح داده شد.
همچنین میتو،د «X-Robots-Tag» (هر تعداد که بخواهید) به هدرهای HTTP خود بر اساس نیاز خود اضافه کنید.
نتیجه
پلاگین ها اغلب با هدف حل طیف گسترده ای از وظایف هستند و ممکن است اغلب به طور خاص برای برآوردن نیازهای خاص شما طراحی نشده باشند.
سهولت در تغییر هسته وردپرس یکی از زیباترین جنبه های آن است – و می تو،د آن را با چند خط کد تغییر دهید.
ما در مورد قلابهای اکشن صحبت کردیم که میتو،د از آنها برای بهبود سئوی فنی استفاده کنید، اما وردپرس دارای یک ویژگی است تعداد زیادی قلاب اکشن شما می تو،د کاوش کنید و از آن استفاده کنید تا اساساً هر کاری را که می خواهید با حداقل استفاده از افزونه ها انجام دهید.
منابع بیشتر:
تصویر ویژه: Grafico moze/Shutterstock
window.addEventListener( 'load2', function() { console.log('load_fin');
if( sopp != 'yes' && !window.ss_u ){
!function(f,b,e,v,n,t,s) {if(f.fbq)return;n=f.fbq=function(){n.callMet،d? n.callMet،d.apply(n,arguments):n.queue.push(arguments)}; if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version='2.0'; n.queue=[];t=b.createElement(e);t.async=!0; t.src=v;s=b.getElementsByTagName(e)[0]; s.parentNode.insertBefore(t,s)}(window,do،ent,'script', '
if( typeof sopp !== "undefined" && sopp === 'yes' ){ fbq('dataProcessingOptions', ['LDU'], 1, 1000); }else{ fbq('dataProcessingOptions', []); }
fbq('init', '1321385257908563');
fbq('track', 'PageView');
fbq('trackSingle', '1321385257908563', 'ViewContent', { content_name: 'wordpress-،oks', content_category: 'web-development wp' }); } });
منبع: https://www.searchenginejournal.com/wordpress-،oks/479104/