ترفندهای مفید برای فایل functions.php وردپرس

5 / 5. تعداد رای: 2

ترفندهای مفید برای فایل functions.php وردپرس

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

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

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

آنچه در این مقاله می‌خوانید

فایل توابع در وردپرس چیست

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

هدف از ایجاد این فایل اجازه دادن به ارائه‌دهندگان قالب برای تعریف از ویژگی‌های قالب و توابع می‌باشد. توابع مختلفی در این فایل وجود دارند که شما می‌توانید از آن‌ها استفاده کنید. همچنین شما می‌توانید در بعضی از سایت‌ها مانند میهن وردپرس با دستورالعملی که به شما می‌گوید چگونه کد را در فایل functions.php و یا یک افزونه وردپرس سایت خاص اضافه کنید؛ بسیاری از این قطعه کدها را پیدا کنید و از آن‌ها در جهت بهبود سایت خود استفاده کنید.

در حالی که فایل functions.php بسیار مناسب و راحت است؛ اما استفاده از افزونه اختصاصی بهتر است. چراکه مستقل از قالب وردپرس است و در نظر نمی‌گیرد که شما از چه افزونه‌ای استفاده می‌کنید. از سمت دیگر فایل تابع قالب فقط برای قالب‌ها کار می‌کند و اگر قالب را تعویض کنید باید کد سفارشی را در قالب جدید کپی کنید.

اکنون چند ترفند مفید برای فایل توابع وردپرس به شما ارائه می‌کنیم:

حذف نسخه وردپرس

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

function wpb_remove_version() {
return '';
}
add_filter('the_generator', 'wpb_remove_version');

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

اگر قصد داشته باشید به ناحیه مدیریت وردپرس خود برچسب سفید اضافه کنید؛ باید یک داشبورد لوگو سفارشی به گام اول پردازش اضافه کنید. برای انجام این کار ابتدا نیاز دارید لوگو سفارشی را در فولدر تصاویر قالب به‌عنوان لوگوی سفارشی فعلی آپلود کنید. همچنین شما باید اطمینان حاصل کنید که سایز لوگوی سفارشی 16×16 پیکسل است. پس از آن امکان این را دارید که کد زیر را به فایل تابع اضافه کنید:

function wpb_custom_logo() {
echo '
<style type="text/css">
#wpadminbar #wp-admin-bar-wp-logo > .ab-item .ab-icon:before {
background-image: url(' . get_bloginfo('stylesheet_directory') . '/images/custom-logo.png) !important;
background-position: 0 0;
color:rgba(0, 0, 0, 0);
}
#wpadminbar #wp-admin-bar-wp-logo.hover > .ab-item .ab-icon {
background-position: 0 0;
}
</style>
';
}
//hook into the administrative header output
add_action('wp_before_admin_bar_render', 'wpb_custom_logo');

تغییر فوتر در پنل مدیریت وردپرس

فوتر در مدیریت وردپرس پیام‌هایی نظیر “سپاسگزاریم از اینکه سایت خود را با وردپرس ساخته‌اید.” را نمایش می‌دهد. اما در برخی از اوقات شما تمایل دارید که این پیام را تغییر داده و متن دلخواه خود را جایگزین ان کنید. بنابراین برای اینکه این متن را تغییر دهید می‌توانید کد زیر را به فایل افزوده و متن را تغییر دهید:

function remove_footer_admin () {

echo 'Fueled by <a href="http://www.wordpress.org" target="_blank">wordpress</a> | WordPress Tutorials: <a href="https://mihanwp.com" target="_blank">MihanWP</a></p>';

}

add_filter('admin_footer_text', 'remove_footer_admin');

افزودن ابزارک سفارشی به داشبورد در وردپرس

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

add_action('wp_dashboard_setup', 'my_custom_dashboard_widgets');

function my_custom_dashboard_widgets() {
global $wp_meta_boxes;

wp_add_dashboard_widget('custom_help_widget', 'Theme Support', 'custom_dashboard_help');
}

function custom_dashboard_help() {
echo '<p>Welcome to Custom Blog Theme! Need help? Contact the developer <a href="mailto:yourusername@gmail.com">here</a>. For WordPress Tutorials visit: <a href="http://www.mihanwp.com" target="_blank">MihanWP</a></p>';
}

نمونه این کار را می‌‌توانید در تصویر زیر مشاهده کنید.

تغییر آواتار پیش‌‌فرض در وردپرس

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

add_filter( 'avatar_defaults', 'wpb_new_gravatar' );
function wpb_new_gravatar ($avatar_defaults) {
$myavatar = 'http://example.com/wp-content/uploads/2017/01/wpb-default-gravatar.png';
$avatar_defaults[$myavatar] = "Default Gravatar";
return $avatar_defaults;
}

اکنون به صفحه تنظیمات>Discussion رفته و آواتار پیش‌فرض خود را انتخاب کنید.

تاریخ کپی‌‌رایت متغیر در فوتر وردپرس

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

function wpb_copyright() {
global $wpdb;
$copyright_dates = $wpdb->get_results("
SELECT
YEAR(min(post_date_gmt)) AS firstdate,
YEAR(max(post_date_gmt)) AS lastdate
FROM
$wpdb->posts
WHERE
post_status = 'publish'
");
$output = '';
if($copyright_dates) {
$copyright = "© " . $copyright_dates[0]->firstdate;
if($copyright_dates[0]->firstdate != $copyright_dates[0]->lastdate) {
$copyright .= '-' . $copyright_dates[0]->lastdate;
}
$output = $copyright;
}
return $output;
}

پس از افزودن این تابع فایل Footer.php را بازکنید و کد زیر را درجایی‌‌که می‌خواهید تاریخ نمایش داده شود اضافه کنید:

<?php echo wpb_copyright(); ?>

به نظر می‌رسد این تابع برای تاریخ اولین ارسال و آخرین ارسال است.

تغییر تصادفی رنگ پس‌زمینه در وردپرس

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

function wpb_bg() { 
$rand = array('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f');
$color ='#'.$rand[rand(0,15)].$rand[rand(0,15)].$rand[rand(0,15)].
$rand[rand(0,15)].$rand[rand(0,15)].$rand[rand(0,15)];
echo $color;
}

در مرحله بعد شما باید فایل Header.php را در قالب ویرایش کنید. لازم است برچسب را قرار دهید و آن را با جایگزین کردن خط زیر اضافه کنید:

<body <?php body_class(); ?> style="background-color:<?php wpb_bg();?>">>

در پایان تغییرات را ذخیره کرده و نحوه عملکرد وب‌سایت را مشاهده نمایید.

تغییر آدرس وردپرس

اگر صفحه ورود وردپرس شما رفرش باشد یا اینکه قادر نباشید به صفحه مدیریت دسترسی یابید؛ بنابراین نیاز به آپدیت آدرس وردپرس دارید. یک راه برای انجام این کار استفاده از فایل Wp-config.php می‌باشد. اما اگر از این روش این کار را انجام دهید قادر به تنظیم آدرس صحیح روی صفحه تنظیمات نخواهید بود. فیلد آدرس سایت و آدرس وردپرس غیرقابل‌ویرایش و قفل خواهد شد. برای حل این مشکل باید کد زیر را در فایل تابع قرار دهید:

update_option( 'siteurl', 'http://example.com' );
update_option( 'home', 'http://example.com' );

فراموش نکنید که نام دامنه خود را جایگزین Example.com کنید. پس از ورود می‌توانید به تنظیمات رفته و آدرس را تنظیم کنید. پس‌ازآن باید کد اضافه‌شده به تابع را حذف کنید. در غیر این صورت آپدیت آدرس‌ها را هر زمان که سایت شما در دسترس بود نگه می‌دارد.

افزودن اندازه تصویر اضافی در وردپرس

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

خب برای انجام این کار باید کد زیر را به فایل تابع قالب اضافه کنید:

add_image_size( 'sidebar-thumb', 120, 120, true ); // Hard Crop Mode
add_image_size( 'homepage-thumb', 220, 180 ); // Soft Crop Mode
add_image_size( 'singlepost-thumb', 590, 9999 ); // Unlimited Height Mode

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

<?php the_post_thumbnail( 'homepage-thumb' ); ?>

افزودن فهرست جدید به قالب وردپرس

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

function wpb_custom_new_menu() {
  register_nav_menu('my-custom-menu',__( 'My Custom Menu' ));
}
add_action( 'init', 'wpb_custom_new_menu' );

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

اکنون کد زیر را به قالب سایت خود، جایی‌‌که می‌خواهید منو جهت‌یابی نمایش داده شود اضافه کنید:

<?php
wp_nav_menu( array( 
    'theme_location' => 'my-custom-menu', 
    'container_class' => 'custom-menu-class' ) ); 
?>

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

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

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

function wpb_new_contactmethods( $contactmethods ) {
// Add Twitter
$contactmethods['twitter'] = 'Twitter';
//add Facebook
$contactmethods['facebook'] = 'Facebook';

return $contactmethods;
}
add_filter('user_contactmethods','wpb_new_contactmethods',10,1);

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

اکنون شما امکان این را دارید که زمینه را در قالب نویسنده مانند زیر نمایش دهید:

<?php echo $curauth->twitter; ?>

اضافه کردن ویجت آماده و یا نوار کناری در قالب وردپرس

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

شما باید جهت انجام این کار کد زیر را به فایل پوسته قالب خود اضافه نمایید:

// Register Sidebars
function custom_sidebars() {

	$args = array(
		'id'            => 'custom_sidebar',
		'name'          => __( 'Custom Widget Area', 'text_domain' ),
		'description'   => __( 'A custom widget area', 'text_domain' ),
		'before_title'  => '<h3 class="widget-title">',
		'after_title'   => '</h3>',
		'before_widget' => '<aside id="%1$s" class="widget %2$s">',
		'after_widget'  => '</aside>',
	);
	register_sidebar( $args );

}
add_action( 'widgets_init', 'custom_sidebars' );

اکنون با رفتن به صفحه‌ی نمایش>ابزارک‌‌‌‌‌ها می‌توانید ناحیه ویجت جدید که آن را به‌دلخواه خود سفارشی کرده‌اید را مشاهده کنید:

علاوه بر این شما می‌توانید جهت نمایش نوار کناری یا ناحیه ویجت در قالب, کد زیر را اضافه کنید:

<?php if ( !function_exists('dynamic_sidebar') || !dynamic_sidebar('custom_sidebar') ) : ?>
<!–Default sidebar info goes here–>
<?php endif; ?>

دست‌‌کاری فوتر خروجی RSS

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

function wpbeginner_postrss($content) {
if(is_feed()){
$content = 'This post was written by Syed Balkhi '.$content.'Check out WPBeginner';
}
return $content;
}
add_filter('the_excerpt_rss', 'wpbeginner_postrss');
add_filter('the_content', 'wpbeginner_postrss');

افزودن ویژگی تصویر به خروجی RSS

همان‌طور که می‌دانید ویژگی تصویر معمولاً با طراحی سایت نمایش داده می‌شود. شما قادر هستید به‌راحتی عملکرد را به خروجی RSS خود با افزودن تابع زیر توسعه دهید:

function rss_post_thumbnail($content) {
global $post;
if(has_post_thumbnail($post->ID)) {
$content = '<p>' . get_the_post_thumbnail($post->ID) .
'</p>' . get_the_content();
}
return $content;
}
add_filter('the_excerpt_rss', 'rss_post_thumbnail');
add_filter('the_content_feed', 'rss_post_thumbnail');

مخفی کردن خطاهای ورود در وردپرس

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

function no_wordpress_errors(){
  return 'Something is wrong!';
}
add_filter( 'login_errors', 'no_wordpress_errors' );

به‌‌این‌‌ترتیب کاربر زمان وارد کردن نام کاربری یا رمز عبور اشتباه یک پیغام خطا دریافت می‌‌کند.

غیرفعال کردن ورود از طریق ایمیل در وردپرس

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

remove_filter( 'authenticate', 'wp_authenticate_email_password', 20 );

غیرفعال کردن قابلیت جستجو در وردپرس

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

function fb_filter_query( $query, $error = true ) {

if ( is_search() ) {
$query->is_search = false;
$query->query_vars[s] = false;
$query->query[s] = false;

// to error
if ( $error == true )
$query->is_404 = true;
}
}

add_action( 'parse_query', 'fb_filter_query' );
add_filter( 'get_search_form', create_function( '$a', "return null;" ) );

تأخیر در خروجی RSS پست‌‌ها

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

function publish_later_on_feed($where) {

	global $wpdb;

	if ( is_feed() ) {
		// timestamp in WP-format
		$now = gmdate('Y-m-d H:i:s');

		// value for wait; + device
		$wait = '10'; // integer

		// http://dev.mysql.com/doc/refman/5.0/en/date-and-time-functions.html#function_timestampdiff
		$device = 'MINUTE'; //MINUTE, HOUR, DAY, WEEK, MONTH, YEAR

		// add SQL-sytax to default $where
		$where .= " AND TIMESTAMPDIFF($device, $wpdb->posts.post_date_gmt, '$now') > $wait ";
	}
	return $where;
}

add_filter('posts_where', 'publish_later_on_feed');

در این کد 10 دقیقه زمان تأخیر داریم. به‌‌صورت رایگان به هر تعداد دقیقه‌‌ای که می‌‌خواهید زمان تأخیر را تغییر دهید.

تغییر متن برای گزیده‌‌ای در وردپرس

شما امکان این را دارید که این متن را به متن دلخواه خود تغییر دهید. این نوشته می‌تواند به‌صورت‌های مختلف در سایت شما نمایش داده شود. بنابراین جهت تغییر متنی که بعد از گزیده‌ای می‌آید، کد زیر را به فایل تابع اضافه کنید:

function modify_read_more_link() {
    return '<a class="more-link" href="' . get_permalink() . '">Your Read More Link Text</a>';
}
add_filter( 'the_content_more_link', 'modify_read_more_link' );

غیرفعال کردن خروجی RSS در وردپرس

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

function fb_disable_feed() {
wp_die( __('No feed available,please visit our <a href="'. get_bloginfo('url') .'">homepage</a>!') );
}

add_action('do_feed', 'fb_disable_feed', 1);
add_action('do_feed_rdf', 'fb_disable_feed', 1);
add_action('do_feed_rss', 'fb_disable_feed', 1);
add_action('do_feed_rss2', 'fb_disable_feed', 1);
add_action('do_feed_atom', 'fb_disable_feed', 1);

تغییر طول خلاصه مطلب در وردپرس

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

functionnew_excerpt_length($length) {
return 100;
}
add_filter('excerpt_length', 'new_excerpt_length');

در نظر داشته باشید که عدد 100 را به هر عددی که می‌‌خواهید در گزیده‌‌ای نمایش دهید می‌‌توانید تغییر دهید.

افزودن کاربر مدیر در وردپرس

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

function wpb_admin_account(){
$user = 'Username';
$pass = 'Password';
$email = 'email@domain.com';
if ( !username_exists( $user )  && !email_exists( $email ) ) {
$user_id = wp_create_user( $user, $pass, $email );
$user = new WP_User( $user_id );
$user->set_role( 'administrator' );
} }
add_action('init','wpb_admin_account');

فیلد نام کاربری، رمز عبور و ایمیل را تکمیل کنید. پس از وارد شدن به سایت وردپرس فراموش نکنید که کد را از فایل تابع حذف کنید.

حذف پنل خوش آمدگویی از داشبورد وردپرس

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

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

remove_action('welcome_panel', 'wp_welcome_panel');

نمایش تعداد کل کاربران ثبت‌نام‌شده در وردپرس

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

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

// Function to return user count
function wpb_user_count() { 
$usercount = count_users();
$result = $usercount['total_users']; 
return $result; 
} 
// Creating a shortcode to display user count
add_shortcode('user_count', 'wpb_user_count');

با افزودن این کد یک کد کوتاه ایجاد می‌شود که به شما اجازه نمایش دادن تعداد کل کاربران ثبت‌نام‌شده را می‌دهد. اکنون باید این کد را به [user_count] هرکجای قالب سایت خود که می‌خواهید تعداد کاربران را در آنجا نمایش دهید اضافه کنید.

حذف دسته خاصی از خروجی RSS

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

function exclude_category($query) {
	if ( $query->is_feed ) {
		$query->set('cat', '-5, -2, -3');
	}
return $query;
}
add_filter('pre_get_posts', 'exclude_category');

فعال کردن اجرای کد کوتاه در متن ابزارک

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

// Enable shortcodes in text widgets
add_filter('widget_text','do_shortcode');

اضافه کردن کلاس زوج و فرد CSS به پست وردپرس

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

function oddeven_post_class ( $classes ) {
   global $current_class;
   $classes[] = $current_class;
   $current_class = ($current_class == 'odd') ? 'even' : 'odd';
   return $classes;
}
add_filter ( 'post_class' , 'oddeven_post_class' );
global $current_class;
$current_class = 'odd';

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

.even {
background:#f0f8ff;  
} 
.odd {
 background:#f4f4fb;
}

نتیجه نهایی مانند تصویر زیر می‌باشد:

اضافه کردن انواع فایل‌های اضافی برای آپلود در وردپرس

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

function my_myme_types($mime_types){
    $mime_types['svg'] = 'image/svg+xml'; //Adding svg extension
    $mime_types['psd'] = 'image/vnd.adobe.photoshop'; //Adding photoshop files
    return $mime_types;
}
add_filter('upload_mimes', 'my_myme_types', 1, 1);

این کد به شما اجازه‌ی آپلود فایل SVG و PSD به وردپرس را می‌دهد. برای پیدا کردن نوع Mime برای انواع فایل که می‌خواهید در کد استفاده کنید نیاز به گوگل دارید.

حذف لینک‌های تصویر پیش‌فرض در وردپرس

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

function wpb_imagelink_setup() {
	$image_set = get_option( 'image_default_link_type' );
	
	if ($image_set !== 'none') {
		update_option('image_default_link_type', 'none');
	}
}
add_action('admin_init', 'wpb_imagelink_setup', 10);

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

اضافه کردن جعبه اطلاعات  نویسنده در پست وردپرس

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

function wpb_author_info_box( $content ) {

global $post;

// Detect if it is a single post with a post author
if ( is_single() && isset( $post->post_author ) ) {

// Get author's display name 
$display_name = get_the_author_meta( 'display_name', $post->post_author );

// If display name is not available then use nickname as display name
if ( empty( $display_name ) )
$display_name = get_the_author_meta( 'nickname', $post->post_author );

// Get author's biographical information or description
$user_description = get_the_author_meta( 'user_description', $post->post_author );

// Get author's website URL 
$user_website = get_the_author_meta('url', $post->post_author);

// Get link to the author archive page
$user_posts = get_author_posts_url( get_the_author_meta( 'ID' , $post->post_author));
 
if ( ! empty( $display_name ) )

$author_details = '<p class="author_name">About ' . $display_name . '</p>';

if ( ! empty( $user_description ) )
// Author avatar and bio

$author_details .= '<p class="author_details">' . get_avatar( get_the_author_meta('user_email') , 90 ) . nl2br( $user_description ). '</p>';

$author_details .= '<p class="author_links"><a href="'. $user_posts .'">View all posts by ' . $display_name . '</a>';  

// Check if author has a website in their profile
if ( ! empty( $user_website ) ) {

// Display author website link
$author_details .= ' | <a href="' . $user_website .'" target="_blank" rel="nofollow">Website</a></p>';

} else { 
// if there is no author website then just close the paragraph
$author_details .= '</p>';
}

// Pass all this info to post content  
$content = $content . '<footer class="author_bio_section" >' . $author_details . '</footer>';
}
return $content;
}

// Add our function to the post content filter 
add_action( 'the_content', 'wpb_author_info_box' );

// Allow HTML in author bio section 
remove_filter('pre_user_description', 'wp_filter_kses');
سپس برای بهتر شدن css سفارشی را اضافه کنید :

.author_bio_section{
background: none repeat scroll 0 0 #F5F5F5;
padding: 15px;
border: 1px solid #ccc;
}

.author_name{
font-size:16px;
font-weight: bold;
}

.author_details img {
border: 1px solid #D8D8D8;
border-radius: 50%;
float: left;
margin: 0 10px 10px 0;
}

نتیجه این کار مانند تصویر زیر می‌شود:

غیرفعال کردن XML-RPC در وردپرس

XML-RPC یک روش است که اجازه می‌دهد برنامه‌های شخص ثالث با سایت وردپرس از راه دور ارتباط برقرار کنند؛ که باعث مسائل امنیتی می‌شود و می‌تواند توسط هکرها مورد سو استفاده قرار گیرد. بنابراین جهت بالا بردن ایمنی سایت حتماً به آن توجه داشته باشید. برای خاموش کردن XML-RPC در وردپرس کد زیر را به فایل تابع اضافه کنید:

add_filter('xmlrpc_enabled', '__return_false');

لینک عکس‌های ویژه به پست به‌طور خودکار

اکثر قالب‌های وردپرس از این قابلیت پشتیبانی می‌کنند. این قابلیت بسیار مفید و کارآمد است و باعث می‌شود سایت شما ظاهر بهتری داشته باشد. اما اگر قالب وردپرس شما به‌صورت خودکار ویژگی تصویر را به پست لینک نمی‌کند، می‌توانید به‌سادگی با افزودن کد زیر به فایل تابع این کار را انجام دهید:

function wpb_autolink_featured_images( $html, $post_id, $post_image_id ) {

If (! is_singular()) { 
	
$html = '<a href="' . get_permalink( $post_id ) . '" title="' . esc_attr( get_the_title( $post_id ) ) . '">' . $html . '</a>';
return $html;

} else { 

return $html;

}

}
add_filter( 'post_thumbnail_html', 'wpb_autolink_featured_images', 10, 3 );

نتیجه‌گیری

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

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

موفق و پیروز باشید. 🙂

نکته خاصی هست که این مقاله رو تکمیل‌تر کنه؟

  1. U334823 ۲۰ تیر ۱۴۰۳

    سلام من داشتم فایل functions.php قالب وودمارت سایت رو ویرایش می کردم که سایت با مشکل مواجه شد و الان ارور زیر نشون داده میشه:
    Parse error: syntax error, unexpected ‘hrNEOj7hJws7iNHKOZFfb’ (T_STRING) in /home/donyaye3/public_html/wp-content/themes/woodmart/functions.php on line 7
    یک خطای مهم در این وب سایت رخ داده است.
    چطور باید مشکل رو حل کنم. هاستینگ سایت پاسخگو نبود و خودم برنامه نویسی بلد نیستم. فکر می‌کنم خط ۷ این فایل ارور داره…

  2. U311198 ۸ بهمن ۱۴۰۰

    سلام
    من حالت دیباگ رو فعال کردم
    این ارور امد
    مشکل از کجاست و چطور باید برطرفش کنم

    Notice: تابع acf_get_value به طورنادرست فراخوانی شد. زمینه‌های سفارشی پیشرفته نسخه حرفه ای – We’ve detected one or more calls to retrieve ACF field values before ACF has been initialized. This is not supported and can result in malformed or missing data. Learn how to fix this. لطفاً برای اطلاعات بیشتر، اشکال زدایی در وردپرس را مشاهده کنید. (این پیام در نگارش 5.11.1 افزوده شده است.) in /home/karsito2……./domains/……../public_html/wp-includes/functions.php on line 5768

    • تیم پشتیبانی تیم پشتیبانی ۱۰ بهمن ۱۴۰۰

      درود
      Warning‌ها و notice هادر وردپرس مشکل خاصی برای سایت شما ایجاد نمی‌کنند. در صورتی که سایت شما مشکل برنامه نویسی داشته باشد، ارور ۵۰۰ دریافت خواهید کرد. در نتیجه نگران این اخطار‌ها نباشید.

  3. U18766 ۱۲ اسفند ۱۳۹۹

    سلام وقت بخیر
    من میخوام به صفحه ورود تایید گوگل اضافه کنم، حالا نسخه 3 یا 2 خیلی فرق نداره، پیشنهاد شما چیه ؟ چه افزونه ای بهترین کار رو انجام میده، من نمیخام توی تمام صفحات کد google فراخوانی بشه، فقط میخام کدش توی صفحه ورود لود بشه و همونجا هم کاربر verfiy بشه، ممنونم از شما

    • Reza Rad رضا راد ۱۲ اسفند ۱۳۹۹

      سلام متاسفانه اکثر افزونه‌ها کد رو در همه صفحات لود می‌کنند. باید این مورد رو بررسی کنید افزونه خاصی مد نظرم نیست. اما google recaptcha را نصب کنید.

  4. U30989 ۳۰ مهر ۱۳۹۹

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

  5. U21054 ۱۰ فروردین ۱۳۹۹

    با سلام و عرض ادب
    تبریک سال نو به تیم مقتدر میهن وب
    آموزش های شما عالی است .جالب است که محتوای عالی آموزشی را که در بعضی از سایت ها در این حد هم نیست می فروشند ولی شما چه محتای فیلم و یا متنی را رایگان ارائه می نمایید .
    خداوند به کسب و کارتان برکت دهد
    ارادتمند امیر عباس رحیمی

    • تیم پشتیبانی تیم پشتیبانی ۱۰ فروردین ۱۳۹۹

      با سلام و احترام
      سپاس فراوان از لطف و توجه شما کاربر گرامی
      امیدواریم که همیشه از خدمات ما راضی باشید
      پیروز باشید

  6. کاربر مهمان ۳۱ اردیبهشت ۱۳۹۶

    ممنون، بسیار کاربردی بود. منتظر بخش دوم آموزش هستیم …