WordPressで構築されたサイト内でAjax通信を行う方法
2025/08/01
WordPressで構築されたサイト内でボタンクリック時等にAjax通信を行いたいというケースがあった。適当なディレクトリに処理用のファイルを設置し、そちらに対してリクエストしても正常に動作せず、何故なのか調べたところWordPress用のお作法みたいなのがあるらしい。以下に対応方法をメモ。
目次
対応方法
Ajax送信側
Ajax送信したいページ(ファイル)に以下を記述する。
admin_url()はWordPress用関数になるが、これを使いたくない(JSファイルで完結させたいような)場合は「/wordpress/wp-admin/admin-ajax.php」のように適宜変更すること。
$(document).on(`click`, `.button`, function(){ $.ajax({ url: `<?php echo admin_url("admin-ajax.php")?>`, //admin-ajax.phpに対して送信(ここは固定) type: 'POST', data: {}, //何らかのデータを送信する場合はこちらで指定 }).done(function( result ){ }).fail(function() { }).always(function() { }); return false; });
受信側
functions.php等に以下を記述する。wp_ajax_{$action}はログイン済みユーザー、wp_ajax_nopriv_{$action}は未ログインのユーザーによるAjaxアクションを実行するためのフックになる。
function ajax_function(){ //何らかの処理 //値を返したい場合はechoで出力 echo $result; //終了させる wp_die(); } add_action( 'wp_ajax_ajax_function', 'ajax_function' ); add_action( 'wp_ajax_nopriv_ajax_function', 'ajax_function' );
リファレンス
admin_url
https://developer.wordpress.org/reference/functions/admin_url/
do_action( "wp_ajax_{$action}" )
https://developer.wordpress.org/reference/hooks/wp_ajax_action/
do_action( "wp_ajax_nopriv_{$action}" )
https://developer.wordpress.org/reference/hooks/wp_ajax_nopriv_action/
関連記事
-
-
WordPressの5系から搭載されたブロックエディタ(Gutenberg)を元に戻す方法
WordPressを5系にアップデートしたところ記事投稿ページのエディタが大幅に ...
-
-
WordPressにて投稿記事及び固定ページの記事数を取得・表示する方法
WordPressにてページ内に記事数を表示したいというケースがあった。また、通 ...
-
-
WordPressで記事検索時に投稿ID順にならない場合の対応方法
WordPressでサイト上から記事検索(キーワード検索)を行った場合、通常であ ...
-
-
WordPressでオリジナルのプラグインを作成する方法
WordPressでオリジナルのプラグインを作成する方法を以下にメモ。 &nbs ...
-
-
WordPressのCron設定(wp-cron.php)を変更し負荷対策する方法
WordPressのcron設定(wp-cron.php)を変更することで負荷が ...