Trusted WordPress tutorials, when you need them most.
Beginner’s Guide to WordPress
WPBカップ
25 Million+
Websites using our plugins
16+
Years of WordPress experience
3000+
WordPress tutorials
by experts

WordPressの関数ファイルの46の非常に便利なトリック

WordPressの関数ファイル(functions.php)は、すべてのWordPressテーマに付属している強力なツールです。プラグインのように機能し、カスタマイザーのコードを簡単にサイトに追加することができます。

私たちのサイトでは、短いコードが使える場合はカスタマイザーを使っています。WordPressのこの汎用性と柔軟性により、複数のプラグインの機能を管理しやすい方法で組み合わせることができます。

この投稿では、WordPressの関数ファイルを使用するための実用的で便利なトリックをいくつか紹介します。

Handy WordPress functions file tips and hacks

WordPressのFunctionsファイルとは?

functions.phpファイルは、無料およびプレミアムWordPressテーマすべてに付属しているWordPressテーマファイルです。

プラグインとして機能し、テーマ開発者がテーマの機能を定義できる。ユーザーはWordPressにカスタムコードスニペットを追加するために使用することもできます。

しかし、カスタマイザー・コードを関数ファイルに保存するのは良いやり方ではない。

テーマを更新すると、functions.phpファイルは上書きされ、カスタマイザーは失われます。スニペットを削除せずにオフにすることはできません。

WPCodeは、テーマやプラグイン、WordPressのコアファイルを編集することなく、WordPressサイトにコードスニペットを挿入できる無料のプラグインです。

なぜWPCodeを推奨するのか?

  • コアファイルを編集することなく、カスタムコードスニペットを簡単に保存できます。
  • 必要な場所にコードスニペットを自動挿入
  • 各コードスニペットは区切りで保存され、個別にオフにすることができる。
  • ビルトインのフェイルセーフ・メカニズムは、コード・スニペットがサイト上でエラーを引き起こした場合に無効化します。

ボーナスとして、WPCodeプラグインは、設定済みのコードスニペットの広範なライブラリを持っています(このリストの多くを含む)。数回クリックするだけで、これらのコード・スニペットを配置することができます。

wpcode library

とはいえ、この投稿で取り上げる項目は以下の通りだ。興味のあるものにジャンプしてもいいし、そのままついていってもいい:

コード・スニペットをサイトに追加する方法

始める前に、この投稿のコード・スニペットをWordPressのfunctionsファイルに追加する方法を見てみよう。

1.WPCodeを使ってカスタムコードを関数ファイルに追加する(推奨)

まず、WPCodeプラグインをインストールし、有効化する必要があります。詳しくは、WordPressプラグインのインストール方法のステップバイステップガイドをご覧ください。

有効化した後、コードスニペット ” + スニペットの追加ページに移動します。WPCodeのコードライブラリには、すでに多くの便利なカスタムコードスニペットが追加されています。

Add snippet

もしあなたのコード・スニペットがライブラリにあるスニペットと同じことをするのであれば、すでに追加されているものを試すことができる。

または、’blank snippet’ リンクをクリックして、カスタムコードスニペットの追加を続行します。

次の画面で、カスタムコードのタイトルを入力します。これは、このコード・スニペットが何をするものかを識別するのに役立つものであれば何でもかまいません。

Adding your custom code

次に、「コードタイプ」を選択する必要があります。functions.phpファイルで動作するコードを追加する場合は、「PHPスニペット」を選択する必要があります。

その下の「コードプレビュー」ボックスにカスタムコードをコピー&ペーストしてください。

最後に、スニペットを「有効化」にして「スニペットを保存」ボタンをクリックします。

Activate and save

保存したスニペットは、functions.phpファイルに追加した場合と同じように実行されます。

スニペットは、必要なときに繰り返し追加することができます。また、スニペットを削除せずに無効化することもできます。

2.カスタムコードを関数ファイルに直接追加する

WPCodeの方法は、テーマの関数ファイルにコードを追加するよりも常に優れています。

しかし、ユーザーによっては、クライアントのカスタムWordPressテーマのためにコードを書いたり、単にfunctions.phpファイルにコードを追加することを好むかもしれません。

その場合、WordPressテーマのfunctions.phpファイルにコードを追加する方法があります。

まず、FTPクライアントを使用してWordPressサイトに接続します。接続したら、/wp-content/themes/your-wordpress-theme/フォルダーに移動します。

Edit functions.php file

そこにfunctions.phpファイルがあります。右クリックして編集を選択するか、ファイルをコンピューターにダウンロードして編集してください。

メモ帳やテキストエディットのようなプレーンテキストエディターで編集できます。

次に、functions.phpファイルの一番下までスクロールダウンし、そこにコード・スニペットを貼り付けます。変更を保存し、更新したfunctions.phpファイルをテーマフォルダーにアップロードします。

これでWordPressサイトにアクセスし、カスタムコードの動作を確認することができます。

それでは、WordPressの関数ファイルに関する46の便利なトリックを見てみよう。

1.WordPressのバージョン番号を削除する

WordPressは常に最新バージョンを使用する必要があります。しかし、WordPressのバージョン番号をサイトから削除したい場合もあるでしょう。

このコード・スニペットを関数ファイルまたは新規WPCodeスニペットとして追加するだけです:

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

詳細な手順については、WordPressのバージョン番号を削除する正しい方法についてのガイドをご覧ください。

WordPressの管理エリアにホワイトラベルを貼りたいですか?最初のステップは、カスタムダッシュボードロゴを追加することです。

まず、カスタムロゴをテーマのimagesフォルダーにcustom-logo.pngとしてアップロードする必要があります。カスタムロゴは、16×16ピクセルの1:1の比率(正方形の画像)である必要があります。

その後、このコードをテーマの関数ファイルまたは新しいWPCodeスニペットとして追加することができます:

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');

詳しくは、WordPressでカスタムダッシュボードロゴを追加する方法をご覧ください。

3.WordPress管理画面でフッターを変更する

WordPress管理エリアのフッターには、「WordPressで作成していただきありがとうございます」というメッセージが表示されています。このコードを追加することで、好きなものに変更することができます:

function remove_footer_admin () {

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

}

add_filter('admin_footer_text', 'remove_footer_admin');

追加したいテキストやリンクは自由に変更してください。テストサイトではこんな感じです。

Admin footer

4.WordPressでカスタムダッシュボードウィジェットを追加する

多くのプラグインやテーマがWordPressダッシュボードにウィジェットを追加しているのを見たことがあるだろう。以下のコードを貼り付ければ、自分でも追加することができる:

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="https://www.wpbeginner.com" target="_blank">WPBeginner</a></p>';
}

こんな感じだろう:

Custom dashboard widget

詳しくは、WordPressでカスタムダッシュボードウィジェットを追加する方法のチュートリアルをご覧ください。

5.WordPressで初期設定のGravatarを変更する。

ブログで初期設定の謎の男のアバターを見たことがありますか?それを簡単に自分のブランドのカスタムアバターに置き換えることができます。

初期設定のアバターとして使用したい画像をアップロードし、このコードを関数ファイルまたはWPCodeプラグインに追加するだけです:

function wpb_custom_default_gravatar( $avatar_defaults ) {
	$myavatar = 'https://example.com/wp-content/uploads/2022/10/dummygravatar.png';
	$avatar_defaults[$myavatar] = 'Default Gravatar';
	return $avatar_defaults;
}
add_filter( 'avatar_defaults', 'wpb_custom_default_gravatar' );

これで、設定 ” ディスカッションのページに行き、初期設定のアバターを選択することができます。

Custom default gravatar

詳しい手順は、WordPressの初期設定グラバターを変更するガイドをご覧ください。

6.WordPressフッターの動的著作権日付

テーマのフッターテンプレートを編集することで、コピーライトの日付を追加することができます。しかし、あなたのサイトがいつ始まったかは表示されませんし、翌年に自動的に変更されることもありません。

このコードは、WordPressのフッターにダイナミックなコピーライトの日付を追加することができます:

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(); ?>

この関数は、あなたの最初の投稿の日付と最後の投稿の日付を探します。そして、この関数を呼び出した場所の年数を返します。

ヒント: WPCodeプラグインを使用している場合、2つのコード・スニペットを組み合わせることができます。その後、スニペット設定の「インサーター」セクションで「サイトワイドフッター」の場所を選択してください。これで、テーマのfooter.phpファイルを編集することなく、自動的にフッターに著作権表示日が表示されます。

Add to footer using WPCode

詳しくは、WordPressで著作権の動的な日付を追加する方法をご覧ください。

7.WordPressの背景色をランダムに変更する

WordPressブログの背景色を、訪問やページのリロードごとにランダムに変更したいですか?簡単にできる方法をご紹介します。

まず、このコードをテーマの関数ファイルかWPCodeプラグインに追加します:

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>タグを見つけ、次の行に置き換える:

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

これで変更を保存し、サイトにアクセスしてこのコードの動作を確認することができます。

Random background colors

詳細と代替方法については、WordPressで背景色をランダムに変更するチュートリアルをご覧ください。

8.WordPressのURL更新

WordPressのログインページが更新され続けたり、管理エリアにアクセスできない場合は、WordPressのURLを更新する必要があります。

一つの方法は、wp-config.phpファイルを使用することです。しかし、そうすると、設定ページで正しいアドレスを設定することができません。WordPress URLとサイトURLフィールドはロックされ、編集できなくなります。

その代わりに、次のコードを関数ファイルに追加すれば解決する:

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

example.comをあなたのドメイン名に置き換えることをお忘れなく。

ログイン中、WordPress管理エリアの「設定」ページでURLを設定できます。

その後、関数ファイルまたはWPCodeに追加したコードを削除してください。そうしないと、サイトにアクセスがあるたびにURLが更新され続けることになります。

9.WordPressで画像サイズを追加する

WordPressでは、画像をアップロードすると自動的に複数の画像サイズが生成されます。また、テーマで使用する画像サイズを追加作成することもできます。

このコードをテーマの関数ファイルまたはWPCodeスニペットとして追加するだけです:

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

このコードは、異なるサイズの3つの新しい画像サイズを作成します。あなたの必須条件を満たすために、自由にコードを調整してください。

このコードを使って、テーマ内の任意の場所に画像サイズを表示することができます:

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

詳細な手順については、WordPressで追加画像サイズを作成するガイドを参照してください。

10.テーマに新規ナビゲーションメニューを追加する

WordPressでは、テーマ開発者がナビゲーションメニューを定義し、それを表示することができます。

このコードをテーマのfunctionsファイルに追加するか、新規WPCodeスニペットとして追加することで、テーマに新しいメニューの場所を定義することができます:

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

WordPressダッシュボードの外観 ” メニューを開き、 、テーマの場所オプションとして「マイカスタムメニュー」が表示されます。

Custom menu location

注: このコードはフルサイト編集機能を持つブロックテーマでも動作します。このコードを追加すると、外観のメニュー画面が有効化されます。

次に、ナビゲーション・メニューを表示したいテーマにこのコードを追加する必要がある:

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

詳細な手順については、WordPressテーマでカスタムナビゲーションメニューを追加する方法のガイドを参照してください。

11.投稿者プロフィールフィールドの追加

WordPressの投稿者プロフィールに追加フィールドを追加したいですか?このコードを関数ファイルに追加するか、新規WPCodeスニペットとして追加することで簡単にできます:

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);

このコードは、WordPressのユーザープロフィールにTwitterとFacebookのフィールドを追加します。

New profile fields

これで、投稿者テンプレートにこれらのフィールドを次のように表示できる:

<?php echo get_the_author_meta('twitter') ?>

WordPress登録でユーザープロフィール欄を追加するガイドもご参照ください。

12.WordPressテーマでウィジェット対応エリアやサイドバーを追加する

これは最もよく使われるコードスニペットのひとつで、WordPressテーマにウィジェット対応エリアやサイドバーを追加することは、すでに多くの開発者が知っています。しかし、知らない人のためにこのリストに載せる価値がある。

以下のコードをfunctions.phpファイルまたは新規WPCodeスニペットとして貼り付けてください:

// 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' );

注: このコードは、フルサイト編集機能を持つブロックテーマでも動作します。このコードを追加すると、外観のウィジェット画面が有効化されます。

これで外観 ” ウィジェットページにアクセスし、新しいカスタムウィジェットエリアを見ることができます。

Custom widget area

このサイドバーまたはウィジェット対応エリアをサイトに表示するには、表示したいテンプレートに以下のコードを追加する必要があります:

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

詳しくは、WordPressで動的なウィジェット対応エリアとサイドバーを追加する方法のガイドをご覧ください。

13.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フィードを完全に操作する方法のガイドをご覧ください。

14.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');

詳しくは、WordPressのRSSフィードに投稿サムネイルを追加する方法をご覧ください。

15.WordPressでログインエラーを非表示にする

ハッカーはログインエラーを利用して、間違ったユーザー名やパスワードを入力したかどうかを推測することができます。WordPressでログインエラーを非表示にすることで、ログインエリアとWordPressサイトをより安全にすることができます。

以下のコードをテーマの関数ファイルまたは新規WPCodeスニペットとして追加するだけです:

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

ユーザー名またはパスワードが正しく入力されなかった場合、一般的なメッセージが表示されるようになりました。

Custom login errors

詳しくは、WordPressのエラーメッセージでログインヒントを無効化するチュートリアルをご覧ください。

16.WordPressでメールによるログインを無効化する

WordPressでは、ユーザーはユーザー名またはメールでログインすることができます。このコードを関数ファイルまたは新規WPCodeスニペットとして追加することで、WordPressでメールによるログインを簡単に無効化することができます:

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

詳しくは、WordPressでメールによるログイン機能を無効化する方法をご覧ください。

17.WordPressの検索機能を無効化する

WordPressサイトの検索機能を無効化したい場合は、このコードを関数ファイルまたは新しいWPCodeスニペットに追加するだけです:

function wpb_filter_query( $query, $error = true ) {
if ( is_search() ) {
$query->is_search = false;
$query->query_vars[s] = false;
$query->query[s] = false;
if ( $error == true )
$query->is_404 = true;
}}

このコードは単に検索クエリーを変更することで無効化し、検索結果の代わりに404エラーを返す。

詳しくは、WordPressの検索機能の無効化に関するチュートリアルをご覧ください。

プロからのアドバイス:WordPress検索をあきらめる代わりに、SearchWPを試してみることをお勧めします。あなたのサイトにパワフルでカスタマイズ可能な検索機能を追加できる、市場で最高のWordPress検索プラグインです。

18.カテゴリー: RSSフィードの投稿を遅らせる

文法エラーやスペルミスのある投稿を公開することもあります。

RSSフィード購読者に配信されます。WordPressブログにメール購読者がいる場合は、その購読者にも通知が届きます。

このコードをテーマのfunctionsファイルに追加するか、新規WPCodeスニペットとして追加するだけで、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');

このコードでは、$waitまたはdelayの時間として10分を使っています。これを自由に変更してください。

プラグインによる方法と詳細については、WordPressのRSSフィードに投稿が表示されるのを遅らせる方法の詳細ガイドをご覧ください。

19.WordPressで抜粋の続きを読むテキストを変更する

投稿の抜粋の後に表示されるテキストを変更したいですか?このコードをテーマの関数ファイルまたは新規WPCodeスニペットとして追加してください:

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' );

20.WordPressでRSSフィードを無効化する

すべてのサイトにRSSフィードが必要なわけではありません。WordPressサイトでRSSフィードを無効化したい場合は、このコードをテーマのfunctionsファイルに追加するか、新規WPCodeスニペットとして追加してください:

function new_excerpt_more($more) {
 global $post;
 return '<a class="moretag" 
 href="'. get_permalink($post->ID) . '">Your Read More Link Text</a>';
}
add_filter('excerpt_more', 'new_excerpt_more');

プラグインによる方法については、WordPressでRSSフィードを無効化する方法をご覧ください。

21.WordPressで抜粋の長さを変更する

WordPressは抜粋の長さを55ワードに制限しています。変更する必要がある場合は、このコードを関数ファイルまたは新規WPCodeスニペットとして追加することができます:

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

100を抜粋で表示したい単語数に変更するだけです。

別の方法として、WordPress抜粋のカスタマイズ方法(コーディング必須)をご覧ください。

22.WordPressで管理ユーザーを追加する

WordPressのパスワードとメールを忘れてしまった場合は、FTPクライアントを使用してテーマのfunctionsファイルにこのコードを追加することで、管理ユーザーを追加することができます:

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');

ユーザー名、パスワード、メールの記入をお忘れなく。

重要WordPressサイトにログインしたら、関数ファイルからコードを削除することを忘れないでください。

このトピックについては、FTPを使ってWordPressに管理ユーザーを追加する方法のチュートリアルをご覧ください。

23.ログインページの言語切り替え無効化

多言語サイトを運営している場合、WordPressはログインページに言語セレクタを表示します。以下のコードをfunctions.phpファイルまたは新規WPCodeスニペットとして追加することで、簡単に無効化できます:

add_filter( 'login_display_language_dropdown', '__return_false' );

24.WordPressの登録ユーザー数を表示する

WordPressサイトの登録ユーザー数を表示したいですか?このコードをテーマの関数ファイルまたは新規WPCodeスニペットとして追加するだけです:

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]を追加するだけです。

詳細とプラグインの方法については、WordPressで登録ユーザーの総数を表示する方法のチュートリアルをご覧ください。

25.RSSフィードから特定のカテゴリーを除外する

WordPressのRSSフィードから特定のカテゴリーを除外したいですか?このコードをテーマの関数ファイルまたは新規WPCodeスニペットとして追加することができます:

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

26.WordPressのコメントでURLリンクを無効化する

初期設定では、WordPressはコメントする際にURLをクリック可能なリンクに変換します。

次のコードをfunctionsファイルに追加するか、新規WPCodeスニペットとして追加することで、これを止めることができます:

remove_filter( 'comment_text', 'make_clickable', 9 );

詳しくは、WordPressのコメントで自動リンクを無効化する方法の投稿をご覧ください。

27.WordPressの投稿に奇数と偶数のCSSクラスを追加する

WordPressのテーマで、WordPressのコメントに奇数または偶数のクラスを使用しているのを見たことがあるかもしれません。これは、1つのコメントがどこで終わり、次のコメントが始まるかをユーザーが視覚化するのに役立ちます。

WordPressの投稿にも同じテクニックを使うことができる。見た目も美しく、ユーザーがコンテンツの多いページを素早くスキャンするのに役立ちます。

このコードをテーマの関数ファイルに追加するだけです:

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';

このコードは、WordPressの投稿に奇数または偶数のクラスを追加するだけです。カスタムCSSを追加することで、投稿のスタイルを変えることができます。

以下はサンプルコードです:

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

最終的にはこのようになる:

Alternating background colors

もっと詳しい説明が必要ですか?WordPressテーマで投稿に奇数/偶数クラスを追加する方法のチュートリアルをご覧ください。

28.WordPressでアップロードできるファイルタイプを追加する

WordPressの初期設定では、最も一般的に使用される限られた数のファイルタイプをアップロードすることができます。しかし、他のファイルタイプを許可するように拡張することができます。

このコードをテーマの関数ファイルに追加するだけです:

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);

このコードを使えば、WordPressにSVGやPSDファイルをアップロードすることができます。

許可したいファイルタイプのMIMEタイプを見つけて、コードタイプで使用する必要がある。

このトピックについては、WordPressでアップロードできるファイルタイプを追加する方法のチュートリアルをご覧ください。

WordPressは初期設定で送信メールに存在しないメールアドレス(wordpress@yourdomain.com)を使用しています。

このメールアドレスはプロバイダーからスパムとして判定される可能性があります。

これを解決するには、WP Mail SMTPプラグインを使用するのが適切な方法です。

WP Mail SMTP

メール到達性の問題を解決し、WordPressのメール送信に実際のメールアドレスを選択できるようになります。

さらに詳しく知りたい方は、WordPressでメールが送信されない問題の解決方法をご覧ください。

一方、これを実際のメール・アドレスに素早く変更したい場合は、次のコードを関数ファイルまたは新しいWPCodeスニペットとして追加してください:

// Function to change email address
function wpb_sender_email( $original_email_address ) {
    return 'tim.smith@example.com';
}
 
// Function to change sender name
function wpb_sender_name( $original_email_from ) {
    return 'Tim Smith';
}
 
// Hooking up our functions to WordPress filters 
add_filter( 'wp_mail_from', 'wpb_sender_email' );
add_filter( 'wp_mail_from_name', 'wpb_sender_name' );

メールアドレスと名前を自分の情報に置き換えることをお忘れなく。

この方法の問題点は、WordPressはまだメール送信にmail()関数を使用しており、そのようなメールはスパムになってしまう可能性が高いことです。

より良い方法については、WordPressの送信メールの送信者名を変更する方法のチュートリアルをご覧ください。

30.WordPress投稿に投稿者情報ボックスを追加する

複数投稿者のサイトを運営していて、投稿の最後に投稿者の経歴を表示したい場合は、この方法を試すことができる。

このコードを関数ファイルまたは新しいWPCodeスニペットとして追加することから始めてください:

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));
	
// Get User Gravatar
$user_gravatar =  get_avatar( get_the_author_meta( 'ID' , $post->post_author) , 90 );

if ( ! empty( $display_name ) )

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

if ( ! empty( $user_description ) )
// Author avatar and bio will be displayed if author has filled in description. 

$author_details .= '<p class="author_details">' . $user_gravatar . 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 noopener">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を追加する必要がある。

このサンプル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;
}

投稿者欄はこのようになります:

Author bio box

プラグインを使った方法とより詳しい手順については、WordPress投稿に投稿者情報ボックスを追加する方法の投稿をご覧ください。

31.WordPressでXML-RPCを無効化する

XML-RPCは、サードパーティアプリがWordPressサイトとリモートで通信できるようにする方法です。これはセキュリティ上の問題を引き起こし、ハッカーに悪用される可能性があります。

WordPressでXML-RPCをオフにするには、以下のコードをfunctionsファイルまたは新規WPCodeスニペットとして追加してください:

add_filter('xmlrpc_enabled', '__return_false');

詳しくはWordPressでXML-RPCを無効化する方法の投稿をご覧ください。

32.おすすめ投稿にアイキャッチ画像を自動リンク

WordPressテーマが自動的にアイキャッチ画像を記事全体にリンクしない場合は、この方法を試すことができる。

このコードをテーマの関数ファイルまたは新規WPCodeスニペットとして追加するだけです:

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 );

WordPressでアイキャッチ画像を自動的に投稿にリンクさせる方法については、こちらの投稿をご覧ください。

33.WordPressでブロックエディターを無効化する

WordPressでは、コンテンツの作成やサイトの編集にモダンで直感的なエディターを使用しています。このエディターは、よく使われるコンテンツやレイアウト要素にブロックを使用するため、ブロックエディターと呼ばれています。

しかし、場合によっては古いクラシックエディターを使う必要があるかもしれません。

ブロックエディターを無効化する最も簡単な方法は、Classic Editorプラグインを使用することです。しかし、区切りのプラグインを使いたくない場合は、以下のコードを関数ファイルか新しいWPCodeスニペットとして追加してください:

add_filter('gutenberg_can_edit_post', '__return_false', 5);
add_filter('use_block_editor_for_post', '__return_false', 5);

詳しくは、ブロックエディターを無効化してクラシックエディターを使う方法のチュートリアルをご覧ください。

34.WordPressでブロックウィジェットを無効化する

WordPressは、WordPress 5.8でクラシックウィジェットからブロックウィジェットに切り替えました。新しいブロックウィジェットは使いやすく、クラシックウィジェットよりもデザインコントロールができます。

しかし、クラシック・ウィジェットを使いたいユーザーもいるでしょう。その場合、テーマの関数ファイルまたは新規WPCodeスニペットで以下のコードを使用できます:

add_filter( 'use_widgets_block_editor', '__return_false' );

詳しくは、ウィジェットブロックを無効化する(クラシックウィジェットを復元する)方法の投稿をご覧ください。

35.WordPressで最終更新日を表示する

訪問者がWordPressブログの投稿やページを表示すると、WordPressテーマは投稿が公開された日付を表示します。これは、ほとんどのブログや静的サイトでは問題ありません。

しかし、WordPressは古い投稿が定期的に更新されるサイトでも使われている。このような出版物では、投稿が最後に更新された日時を表示することが不可欠です。

Last updated date

テーマの関数ファイルまたは新規WPCodeスニペットで以下のコードを使用して、最終更新日を表示できます:

$u_time          = get_the_time( 'U' );
$u_modified_time = get_the_modified_time( 'U' );
// Only display modified date if 24hrs have passed since the post was published.
if ( $u_modified_time >= $u_time + 86400 ) {

	$updated_date = get_the_modified_time( 'F jS, Y' );
	$updated_time = get_the_modified_time( 'h:i a' );

	$updated = '<p class="last-updated">';

	$updated .= sprintf(
	// Translators: Placeholders get replaced with the date and time when the post was modified.
		esc_html__( 'Last updated on %1$s at %2$s' ),
		$updated_date,
		$updated_time
	);
	$updated .= '</p>';

	echo wp_kses_post( $updated );
}

別の方法や詳細については、WordPressで最終更新日を表示する方法をご覧ください。

36.アップロードには小文字のファイル名を使用してください。

複数の投稿者がいるサイトを運営している場合、投稿者はファイル名を大文字または小文字にして画像をアップロードすることができます。

以下のコードを追加すると、ファイル名がすべて小文字になる:

add_filter( 'sanitize_file_name', 'mb_strtolower' );

注意:このコードでは、既存のアップロードのファイル名は変更されません。別の方法については、WordPressで画像やメディアファイルの名前を変更する方法のチュートリアルを参照してください。

37.フロントエンドのWordPress管理バーを無効化する

WordPressの初期設定では、ログイン中のユーザーがサイトを表示すると、上部に管理バーが表示されます。

サイト管理者以外のすべてのユーザーに対して、管理バーを無効化することができます。以下のコードを関数ファイルまたは新規WPCodeスニペットとして追加してください:

/* Disable WordPress Admin Bar for all users */
add_filter( 'show_admin_bar', '__return_false' );

詳しくは、管理者以外のすべてのユーザーのWordPress管理バーを無効化する方法をご覧ください。

38.管理エリアのHowdy管理者テキストの変更

WordPressのダッシュボードに「Howdy Admin」という挨拶が表示されます。Admin」はログイン中のユーザー名に置き換えられます。

Howdy greeting

初期設定の挨拶は、以下のコードを関数ファイルまたは新規WPCodeスニペットとして追加することで、独自の挨拶に変更することができます:

function wpcode_snippet_replace_howdy( $wp_admin_bar ) {

	// Edit the line below to set what you want the admin bar to display intead of "Howdy,".
	$new_howdy = 'Welcome,';

	$my_account = $wp_admin_bar->get_node( 'my-account' );
	$wp_admin_bar->add_node(
		array(
			'id'    => 'my-account',
			'title' => str_replace( 'Howdy,', $new_howdy, $my_account->title ),
		)
	);
}

add_filter( 'admin_bar_menu', 'wpcode_snippet_replace_howdy', 25 );

詳しくは、WordPressの「Howdy Admin」メッセージの変更に関する投稿をご覧ください。

39.ブロックエディターでのコード編集無効化

ブロックエディターでは、コードエディターに切り替えることができます。手動でHTMLコードを追加する必要がある場合に便利です。

しかし、この機能をサイト管理者に限定しておきたい場合もあるでしょう。

これを実現するには、次のコードを関数ファイルまたはWPCodeスニペットとして追加します:

add_filter( 'block_editor_settings_all', function ( $settings ) {
	
	$settings['codeEditingEnabled'] = current_user_can( 'manage_options' );

	return $settings;
} );

40.プラグイン/テーマファイルエディターの無効化

WordPressにはプラグインファイルを編集できるエディターがビルトインされています。プラグイン ” プラグインファイルエディターのページで見ることができます。

Plugin file editor in WordPress

同様に、WordPressにはクラシックテーマ用のファイルエディターが外観 ” テーマファイルエディターにあります。

注:ブロックテーマを使用している場合、テーマファイルエディターは表示されません。

Theme file editor

テーマやプラグインの変更にこれらのエディターを使用することはお勧めしません。コードのわずかなミスで、すべてのユーザーがサイトにアクセスできなくなる可能性があります。

プラグイン/テーマエディターを無効化するには、以下のコードを関数ファイルまたはWPCodeスニペットとして追加してください:

// Disable the Plugin and Theme Editor
if ( ! defined( 'DISALLOW_FILE_EDIT' ) ) {
	define( 'DISALLOW_FILE_EDIT', true );
}

詳しくはWordPressのプラグイン/テーマエディターを無効化する方法のチュートリアルをご覧ください。

41.新規ユーザー通知メールの無効化

初期設定では、WordPressは新規ユーザーがWordPressサイトに参加するとメール通知を送信します。

WordPressで会員制サイトを運営している場合や、ユーザー登録が必須の場合は、ユーザーがサイトに参加するたびに通知が届きます。

これらの通知をオフにするには、関数ファイルまたは新規WPCodeスニペットとして以下を追加します:

function wpcode_send_new_user_notifications( $user_id, $notify = 'user' ) {
	if ( empty( $notify ) || 'admin' === $notify ) {
		return;
	} elseif ( 'both' === $notify ) {
		// Send new users the email but not the admin.
		$notify = 'user';
	}
	wp_send_new_user_notifications( $user_id, $notify );
}

add_action(
	'init',
	function () {
		// Disable default email notifications.
		remove_action( 'register_new_user', 'wp_send_new_user_notifications' );
		remove_action( 'edit_user_created_user', 'wp_send_new_user_notifications' );

		// Replace with custom function that only sends to user.
		add_action( 'register_new_user', 'wpcode_send_new_user_notifications' );
		add_action( 'edit_user_created_user', 'wpcode_send_new_user_notifications', 10, 2 );
	}
);

詳しくは、WordPressで新規ユーザーのメール通知を無効化する方法のチュートリアルをご覧ください。

42.自動更新メール通知の無効化

WordPressは、セキュリティアップデートやメンテナンスアップデートを自動的にインストールしたり、重大な脆弱性を持つプラグインを更新したりすることがあります。

更新のたびに自動更新メールを送信します。複数のWordPressサイトを管理している場合、このようなメールが何通も届くことがあります。

このコードをfunctionsファイルに追加するか、新規WPCodeスニペットとして追加することで、これらのメール通知をオフにすることができます:

/ Disable auto-update emails.
add_filter( 'auto_core_update_send_email', '__return_false' );

// Disable auto-update emails for plugins.
add_filter( 'auto_plugin_update_send_email', '__return_false' );

// Disable auto-update emails for themes.
add_filter( 'auto_theme_update_send_email', '__return_false' );

さらに詳しく知りたい方は、WordPressの自動更新メールを無効化する方法の投稿をご覧ください。

43.リンクを追加して投稿を簡単にDuplicateする

公開する投稿に触れることなく、編集のために投稿のコンテンツをすべてコピーする簡単な方法を望んだことがありますか?

次のコード・スニペットは、投稿をすべてのコンテンツとともに簡単に複製するオプションを追加します:

// Add duplicate button to post/page list of actions.
add_filter( 'post_row_actions', 'wpcode_snippet_duplicate_post_link', 10, 2 );
add_filter( 'page_row_actions', 'wpcode_snippet_duplicate_post_link', 10, 2 );

// Let's make sure the function doesn't already exist.
if ( ! function_exists( 'wpcode_snippet_duplicate_post_link' ) ) {
	/**
	 * @param array   $actions The actions added as links to the admin.
	 * @param WP_Post $post The post object.
	 *
	 * @return array
	 */
	function wpcode_snippet_duplicate_post_link( $actions, $post ) {

		// Don't add action if the current user can't create posts of this post type.
		$post_type_object = get_post_type_object( $post->post_type );

		if ( null === $post_type_object || ! current_user_can( $post_type_object->cap->create_posts ) ) {
			return $actions;
		}


		$url = wp_nonce_url(
			add_query_arg(
				array(
					'action'  => 'wpcode_snippet_duplicate_post',
					'post_id' => $post->ID,
				),
				'admin.php'
			),
			'wpcode_duplicate_post_' . $post->ID,
			'wpcode_duplicate_nonce'
		);

		$actions['wpcode_duplicate'] = '<a href="' . $url . '" title="Duplicate item" rel="permalink">Duplicate</a>';

		return $actions;
	}
}

/**
 * Handle the custom action when clicking the button we added above.
 */
add_action( 'admin_action_wpcode_snippet_duplicate_post', function () {

	if ( empty( $_GET['post_id'] ) ) {
		wp_die( 'No post id set for the duplicate action.' );
	}

	$post_id = absint( $_GET['post_id'] );

	// Check the nonce specific to the post we are duplicating.
	if ( ! isset( $_GET['wpcode_duplicate_nonce'] ) || ! wp_verify_nonce( $_GET['wpcode_duplicate_nonce'], 'wpcode_duplicate_post_' . $post_id ) ) {
		// Display a message if the nonce is invalid, may it expired.
		wp_die( 'The link you followed has expired, please try again.' );
	}

	// Load the post we want to duplicate.
	$post = get_post( $post_id );

	// Create a new post data array from the post loaded.
	if ( $post ) {
		$current_user = wp_get_current_user();
		$new_post     = array(
			'comment_status' => $post->comment_status,
			'menu_order'     => $post->menu_order,
			'ping_status'    => $post->ping_status,
			'post_author'    => $current_user->ID,
			'post_content'   => $post->post_content,
			'post_excerpt'   => $post->post_excerpt,
			'post_name'      => $post->post_name,
			'post_parent'    => $post->post_parent,
			'post_password'  => $post->post_password,
			'post_status'    => 'draft',
			'post_title'     => $post->post_title . ' (copy)',// Add "(copy)" to the title.
			'post_type'      => $post->post_type,
			'to_ping'        => $post->to_ping,
		);
		// Create the new post
		$duplicate_id = wp_insert_post( $new_post );
		// Copy the taxonomy terms.
		$taxonomies = get_object_taxonomies( get_post_type( $post ) );
		if ( $taxonomies ) {
			foreach ( $taxonomies as $taxonomy ) {
				$post_terms = wp_get_object_terms( $post_id, $taxonomy, array( 'fields' => 'slugs' ) );
				wp_set_object_terms( $duplicate_id, $post_terms, $taxonomy );
			}
		}
		// Copy all the custom fields.
		$post_meta = get_post_meta( $post_id );
		if ( $post_meta ) {

			foreach ( $post_meta as $meta_key => $meta_values ) {
				if ( '_wp_old_slug' === $meta_key ) { // skip old slug.
					continue;
				}
				foreach ( $meta_values as $meta_value ) {
					add_post_meta( $duplicate_id, $meta_key, $meta_value );
				}
			}
		}

		// Redirect to edit the new post.
		wp_safe_redirect(
			add_query_arg(
				array(
					'action' => 'edit',
					'post'   => $duplicate_id
				),
				admin_url( 'post.php' )
			)
		);
		exit;
	} else {
		wp_die( 'Error loading post for duplication, please try again.' );
	}
} );

コードを追加した後、投稿 ” すべての投稿画面に行き、投稿タイトルにマウスオーバーします。

オプション設定の下に新しく「Duplicator」リンクが追加されていることにお気づきでしょう。

Duplicate post link

リンクをクリックすると、すべてのコンテンツを含む投稿のコピーが作成されます。その後、その下書きで作業することができます。

完了したら、公開した元の投稿に変更内容をコピー&ペーストし、コピーを削除することができます。

プラグインを使用する方法については、WordPressの投稿やページを複製する方法の投稿をご覧ください。

44.WordPress管理ダッシュボードからウェルカムパネルを削除する

ウェルカムパネルはWordPress管理画面のダッシュボードに表示されます。表示オプション」ボタンをクリックすることで、簡単に非表示にすることができます。

Welcome panel

しかし、ユーザーによりクリーンなダッシュボードを体験してもらうためなら、非表示にすることもできる。

以下のコードを追加して、サイトのすべてのユーザーに対して無効化してください:

add_action(
	'admin_init',
	function () {
		remove_action( 'welcome_panel', 'wp_welcome_panel' );
	}
);

45.WordPress管理画面で投稿におすすめ画像カラムを追加する

初期設定では、WordPressはサイトを表示しているとき、または投稿やページを編集したときにのみ、おすすめ投稿画像を表示します。

以下のコードは、投稿 ” すべての投稿画面に、アイキャッチ画像用の新しいカラムを追加します:

add_filter( 'manage_posts_columns', function ( $columns ) {
	// You can change this to any other position by changing 'title' to the name of the column you want to put it after.
	$move_after     = 'title';
	$move_after_key = array_search( $move_after, array_keys( $columns ), true );

	$first_columns = array_slice( $columns, 0, $move_after_key + 1 );
	$last_columns  = array_slice( $columns, $move_after_key + 1 );

	return array_merge(
		$first_columns,
		array(
			'featured_image' => __( 'Featured Image' ),
		),
		$last_columns
	);
} );

add_action( 'manage_posts_custom_column', function ( $column ) {
	if ( 'featured_image' === $column ) {
		the_post_thumbnail( array( 300, 80 ) );
	}
} );

コードを追加した後の表示は以下のようになる。

Featured image column

46.管理者以外のWordPress管理エリアをブロックする

WordPressサイトによっては、ユーザーにアカウント登録が必要な場合があります。例えば、WordPressの会員制サイトやeコマースストアなどです。

そのようなプラグインのほとんどは、そのようなユーザーが管理エリアにアクセスできないようにします。しかし、そのようなプラグインを使っていない場合は、以下のコードを追加することで、管理者以外のすべてのユーザーが管理エリアにアクセスするのをブロックすることができます:

add_action( 'admin_init', function() {
	if ( ! current_user_can( 'administrator' ) ) {
       wp_redirect( home_url() );
       exit;
	}
} );

他のユーザー権限を持つユーザーもアカウントにログインできますが、ログイン記録後はホームページにリダイレクトされます。

この投稿がWordPressのfunctions.phpファイルの新しい便利なトリックを学ぶのに役立てば幸いです。また、WordPressでコードを表示してスニペットを簡単に共有する方法や、専門家が選ぶMacとWindows用の最高のコードエディターもご覧ください。

If you liked this article, then please subscribe to our YouTube Channel for WordPress video tutorials. You can also find us on Twitter and Facebook.

情報開示 私たちのコンテンツは読者支援型です。これは、あなたが私たちのリンクの一部をクリックした場合、私たちはコミッションを得ることができることを意味します。 WPBeginnerの資金源 をご覧ください。3$編集プロセスをご覧ください。

アバター

Editorial Staff at WPBeginner is a team of WordPress experts led by Syed Balkhi with over 16 years of experience in WordPress, Web Hosting, eCommerce, SEO, and Marketing. Started in 2009, WPBeginner is now the largest free WordPress resource site in the industry and is often referred to as the Wikipedia for WordPress.

究極のWordPressツールキット

ツールキットへの無料アクセス - すべてのプロフェッショナルが持つべきWordPress関連製品とリソースのコレクション!

Reader Interactions

114件のコメント返信を残す

  1. Moinuddin Waheed

    So much to accomplish with the help of functions.php
    I think this is the core of the WordPress and if we do too much to it, we may lose many core functionalities.
    having said this, using wpcode is a wise idea to insert anything for functionality without compromising the WordPress core.
    I have a question though, if wpcode doesn’t insert it’s code in the main functions.php then how it works?
    and if inserts it into the same, how updating wordpress doesn’t erase it?

    • WPBeginner Support

      The code is stored in your database and the plugin hooks in the code in different ways depending on how you set it in the plugin.

      管理者

  2. Jiří Vaněk

    I’ve noticed that on some websites, the top part of the browser changes color, specifically on mobile Chrome. Do you have any tested snippet that accomplishes this?

  3. Ralph

    A lot of great ideas explained in novice friendly way. Thanks! I will try adding featured images to RSS feeds. It never worked before for some reason and now it will :)

    • WPBeginner Support

      Glad to hear you found our tricks helpful :)

      管理者

  4. Ben

    This is a pretty dangerous idea. Query strings exist for the purposes of cache busting, aka, making sure the end user has the latest version your js and css files.

    Removing those is going to cause all sorts of issues for returning users down the line as their browser will assume nothing has changed and use their cached version rather than downloading the new one.

    If for some reason you need to target a specific file and remove the query string (which I’ve had to do) you can use this code snippet:

    // remove version from scripts and styles
    function remove_version_scripts_styles($src) {
    if (strpos($src, ‘yourfile.js’)) {
    $src = remove_query_arg(‘ver’, $src);
    }
    return $src;
    }
    add_filter(‘script_loader_src’, ‘remove_version_scripts_styles’, 9999);

  5. Gean Paulo Francois

    Very useful article. I just saved this page offline so I can insert some of these with my websites. Anyway, should I add the codes to functions,php and not anywhere else?

    • WPBeginner Support

      Correct, these codes are for your functions.php file.

      管理者

  6. Hussain Badusha

    Nice compendium of some useful tricks and functions for wordpress. I added quite a new things to my wordpress knowledge after going through here.

    I look forward even more from you if you wish to

    • WPBeginner Support

      Glad you found our guide helpful :)

      管理者

  7. Satinder Satsangi

    Oh WoW,

    This is lifesaver most of the times, would like to know more about useful functions.

    • WPBeginner Support

      Glad you found our guide helpful :)

      管理者

  8. vivek

    Nice article,

    Just have a doubt if I am supposed to add these codes in snippets plugin or somwhere in file? if its snippet plugin, it’s not working. Kindly put some light.
    Thanks

    • WPBeginner Support

      You would add these codes as a custom plugin or more commonly in your functions.php file

      管理者

  9. Beulah Wellington

    Thank you for this tutorial. I learned a lot. I will be reading it again.

    • WPBeginner Support

      You’re welcome, glad our guide can continue to help you :)

      管理者

  10. Ali Jahani

    Hi
    Thanks a lot of….

    wpbeginner Is god team

    • WPBeginner Support

      You’re welcome, glad you like our content :)

      管理者

  11. VISHAL CHOWDHRY

    Superb Article.
    Waiting for more of this :)

    • WPBeginner Support

      Thank you, glad you liked our content :)

      管理者

  12. Miley Cyrus

    Great Article it its really informative and innovative keep us posted with new updates. its was really valuable. thanks a lot.

    • WPBeginner Support

      Glad our article could be helpful :)

      管理者

  13. John Dee

    Almost NONE of these code snippets belong in your theme’s functions.php file. Only a few of them are related to the actual theme. Themes are for APPEARANCE. Create a PLUGIN for functionality. In any case, it would go in child theme’s functions.php file.

    • WPBeginner Support

      Thank you for pointing this out, while we do mention site-specific plugins at the beginning of this article, we will be sure to look into making that statement clearer.

      管理者

  14. Suman Samanta

    Nice information for a new bloggers. It is really helpful.

  15. Richard Yzenbrandt

    Thank you so much for making this resource available. WP for Beginners is the best goto site on the web!

  16. alok patel

    hey i am unable to add my post on specific page. when i write any blog post it shows in home page but i wanna also see in specific pages where i want to add. how i can out of from this problem. plz help me as soon as possible. if any video link thn plz share with reply. i m getting too much confused.

  17. DONALD

    I am creating a form to collect data from my users.
    I have created the database from myphpAdmin
    I have created the form.
    I now created a new php.file in my child theme
    I referenced it in the form too using action = “name.php”
    Now i expect it to gather, peoples registration details.
    But clicking on submit on the form, says, page cannot be found.
    I dont know what i am not getting right.
    Please help me

  18. marvin N N

    is there a plugin one can use to customise a theme’s default menu setting to suit your taste???

  19. Sazzad Hossain

    Thanks for this codes.

  20. Shafiq Khan

    Very useful post thanks.

    A question – Because you’re updating the functions.php of a theme.
    If you update the theme then you lose your tweaks.

    Is there a way around this? Is it just a cause of using a Child theme?

    Thanks

    • Lisa

      Hi Shafiq,

      Any changes you make to a parent theme will be overwritten when you update it. It is good practice to work with a child theme when making changes to a theme you didn’t build that is going to be updated so that you can keep the changes you made.

    • Jan

      I use the plugin ‘My Custom Functions’ – it is simply adding all functions to the functions.php automatically – so no re-writing after every update needed :)

    • Jane Lawson

      This is late, but you can also create a plugin for your site (e.g. “[Site name]’s custom plugin”). It does require a bit of expertise, however, since some functions clash with other plugins/the site theme.

  21. Neil

    Excellent post – thank you for the tips & tricks. They are all very helpful :)

  22. Karakaplan

    How to use these above with child theme functions file?

    • Minhaz

      Nothing difference with parent or child theme’s functions.php

  23. Joe

    I’ve not done much with the functions file so it was good to see this article.

    Thanks.

  24. Jorge Rosa

    Great snippets. Very handy and useful. Thank You!

  25. sriganesh

    this is best site for wordpress

  26. Bilal

    will you tell me a most easy book for wordpress.
    i am very new in this field .
    thanks in advance

  27. Al1

    Another one :

    // Remove query string from static files :
    function remove_cssjs_ver( $src ) {
    if( strpos( $src, ‘?ver=’ ) )
    $src = remove_query_arg( ‘ver’, $src );
    return $src;
    }
    add_filter( ‘style_loader_src’, ‘remove_cssjs_ver’, 10, 2 );
    add_filter( ‘script_loader_src’, ‘remove_cssjs_ver’, 10, 2 );

  28. siva

    Great post, Could provide all wordpress function with example

  29. shojib

    This is the best blog for WordPress users.

  30. Parveen

    Great post!!!
    I am a newbie and looking for such tricks.
    Thanks.

  31. Deepak Kanyan

    Really a nice blog. i had learn lot of things from here thanks admin.

  32. Andrew

    I tried #16 to add the post featured thumbnail to m RSS feed but when I tested it in mailchimp (paused my campaign and previewed) it appears that it has changed from “summary” to “full text”? Is this expected behaviour? I want to leave the emails (rss driven) as summary, and simply add the thumbnail featured image at the top.

    Thanks for any help, I can’t find this on google anywhere.

  33. Em Cloney

    re: removing rss feed for static pages — is it correct that the txt one would replace in that code is ‘url’ (with a page link, including ) and ‘homepage’ (if you’d like it to say something else, like ‘some other site’)?

  34. Mohan Manohar

    This is huge list and great help. would like to know the first part of twitter counter code is to be pasted in function.php or directly into texty widget of theme.

  35. grafx

    There is an easier way to remove WordPress Version Number…

    remove_action(‘wp_head’, ‘wp_generator’);

  36. DANISH

    such a great and useful tricks.. :)

  37. Marco

    thank you so much!

  38. Webtechideas

    Such a nice list of useful tricks. It will help both plugin and theme developers.

  39. ahmed

    In #14, isn’t that a instead of ?

  40. Mick O

    Thanks for the helpful article. I really appreciate it. Can you possibly explain why the snippet to add Google analytics (#1) code includes the php declarations. If I have an existing functions.php file that is already defined with , do I need to include the markers again in the snippet? I’m trying to add other customizations into the functions.php and it’s getting hard to keep track.

    • Editorial Staff

      It includes opening php because it is closing PHP tag to allow you to paste plain HTML Google analytics code.

      管理者

  41. Luke Gibson

    The one about the copyright date seems a little OTT when you could simply cut and paste in © 2006- and it would do exactly the same job, just replace 2006 with whatever static start date you wish. Or am I missing something?

    • Editorial Staff

      Yes, you can definitely do that. But if you are releasing this as part of a theme meant for distribution, then you can’t do that.

      管理者

  42. Zeeshan Arshad

    Excellent, I was done with my theme and learning but there was much left. This post saved my day and of course I learnt many things as well.

    Best Wishes!

  43. DesignSkew

    In “Add Author Profile Fields”, the function you mentioned to echo is not working.

  44. Mark

    Great set of tools. I immediately copied the guest author function as I saw it and will now disable a clumsy plugin I’ve been using. Do you have a function that will provide the post ID of the item being worked with in the editor? I’m trying to auto fill a form with media attachments for the current post but have only been able to get it to work in a custom meta-box but not in a thickbox . The thickbox returns all the media files for all the posts when I just want the current posts’s attachments.

  45. mommyblogger

    Thanks for the great WordPress tips! I was hoping you could help me with an additional one?

    I’d like to prevent my tags/categories from spilling over onto another line by limiting the number of tags/categories that appear in the footer of my individual homepage posts. Is it possible to do this with the “the_excerpt”? I would also like the excerpt to be a “…read more” link and limit the number of characters in it. Here is the code it would need to be added to;

    $tags_list = get_the_tag_list( ”, __( ‘, ‘, ‘mummyblog’ ) ); if ( $tags_list ): ?> <li> <?php printf( __( ‘<span class=”%1$s”>Tagged</span> %2$s’, ‘mummyblog’ ), ‘entry-utility-prep entry-utility-prep-tag-links’, $tags_list ); ?> </li> <?php endif; // End if $tags_list ?>

    Thanks!

  46. SteveEBoy

    Like all the others have said below – just too good, a massive help for a newbie and very useful for learning too. Great site all round. Thanks.

  47. LambrosPower

    one of the best tutorials i read. Many important topics pointed out and for sure i didn’t know most of them since i just started wordpress custom design.

  48. Xiaozhuli

    This article is endlessly useful. I bookmarked it and often refer to it when updating my theme or trying to answer a question. Great job!

  49. Mohammad Yeasin

    You guys are just awesome. You know what, wpbegineer is the first website for which i have a separate folder in my bookmark menu. Too good for a wp begineer. youe name suits ur personality. lolz. One day i would must do something special for you. Inshallah.
    The only problem i face is related post with thumbnail. your coder are not working. vDont know what to do. Whatever, Keep up the marvelous job. Love the site wpbegineer.

  50. AA

    Great post! You obviously know a lot about wordpress coding so I’m hoping you can answer a question. How to you remove the date & time stamp from a wordpress feed-rss? I’ve looked everywhere and can’t find any information on this. I’m working on a wordpress “site” and do not have a use for the dates. I have already removed them from the posts & pages.

    Much thanks in advance!

    • Editorial Staff

      Date is NOT optional for RSS feeds. It is a MUST because that is how posts / articles are organized (reverse chronological order). You can remove the display of dates from the template, but you cannot remove them from the XML.

      管理者

返信を残す

コメントありがとうございます。すべてのコメントは私たちのコメントポリシーに従ってモデレートされ、あなたのメールアドレスが公開されることはありませんのでご留意ください。名前欄にキーワードを使用しないでください。個人的で有意義な会話をしましょう。