ホームページ >バックエンド開発 >PHPチュートリアル >WordPress フロントエンドで AJAX 呼び出しを成功させるにはどうすればよいですか?

WordPress フロントエンドで AJAX 呼び出しを成功させるにはどうすればよいですか?

Patricia Arquette
Patricia Arquetteオリジナル
2024-11-01 00:14:02819ブラウズ

How to Make Successful AJAX Calls in WordPress Frontend?

WordPress での AJAX の呼び出し: ゼロ以外の結果を出力するための包括的なガイド

WordPress で AJAX 呼び出しを行う場合は、フロントエンド環境とバックエンド環境の違い。 WordPress はバックエンドでグローバル ajaxurl 変数を定義しますが、この変数はフロントエンドでは定義されません。したがって、フロントエンドで AJAX 呼び出しを使用するには、この変数を自分で明示的に定義する必要があります。

wp_localize_script の使用:

フロントエンドで ajaxurl 変数を定義するための実用的なアプローチwp_localize_script 関数を使用することです。たとえば、AJAX 呼び出しが my-ajax-script.js という名前の JS ファイルに含まれている場合、次のようにローカライズできます:

<code class="php">function my_enqueue() {
    wp_enqueue_script( 'ajax-script', get_template_directory_uri() . '/js/my-ajax-script.js', array('jquery') );
    wp_localize_script( 'ajax-script', 'my_ajax_object', array( 'ajax_url' => admin_url( 'admin-ajax.php' ) ) );
}
add_action( 'wp_enqueue_scripts', 'my_enqueue' );</code>

JavaScript での my_ajax_object 変数の使用:

JS ファイルをローカライズすると、my_ajax_object オブジェクトにアクセスできるようになります。これにより、AJAX を使用して PHP 関数にデータを渡すことができます:

<code class="javascript">jQuery.ajax({
    type: "post",
    dataType: "json",
    url: my_ajax_object.ajax_url,
    data: formData,
    success: function(msg){
        console.log(msg);
    }
});</code>

以上がWordPress フロントエンドで AJAX 呼び出しを成功させるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。