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のテーマファイル内で取得したオブジェクトを指定のフィールド名でソートする方法
WordPressのテーマファイル内で記事やカテゴリ一覧等を取得するとオブジェク ...
-
-
wp_mail関数でエンベロープFrom(Return-Path)が指定できない場合の対応方法
WordPress内に設置されたお問い合わせのフォームようなシステムでエンベロー ...
-
-
WordPressでユーザー毎にフラグを持たせ分岐処理を行う方法
WordPressでユーザー毎に何らかのフラグを持たせて、フラグによって分岐処理 ...
-
-
XML-RPCライブラリを利用してWordPressを外部サーバから投稿する方法
WordPressをダッシュボードからではなく、外部サーバのプログラムから投稿し ...
-
-
Advanced Custom Fieldsで設定した項目を条件に記事一覧を取得する方法
WordPressでAdvanced Custom Fieldsにて設定した項目 ...