「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > WordPress AJAX 呼び出しが 0 を返すのはなぜですか?

WordPress AJAX 呼び出しが 0 を返すのはなぜですか?

2024 年 11 月 8 日に公開
ブラウズ:206

Why is my WordPress AJAX call returning 0?

WordPress での Ajax 呼び出し: 出力の問題のトラブルシューティング

Ajax 呼び出しは出力として常に 0 を返し、原因について困惑しています。この問題を修正するには、次の点を考慮してください。

WordPress のグローバル ajaxurl 変数:

WordPress は、AJAX 呼び出しを容易にするバックエンドでグローバル ajaxurl 変数を定義します。ただし、この変数はフロントエンドでは使用できません。

フロントエンドで ajaxurl を定義する:

フロントエンドで AJAX 呼び出しを利用するには、ajaxurl 変数を手動で定義する必要があります。 。効果的な方法の 1 つは、wp_localize_script.

wp_localize_script を使用することです。

AJAX 呼び出しが my-ajax-script.js にあると仮定して、次のように wp_localize_script を使用します。

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

これにより、ajax_url を含む my_ajax_object オブジェクトが JS ファイルに作成されます。

Javascript で my_ajax_object を利用する:

スクリプトをローカライズした後、JS ファイルで my_ajax_object オブジェクトを利用します。

jQuery.ajax({
    type: "post",
    dataType: "json",
    url: my_ajax_object.ajax_url,
    data: formData,
    success: function(msg){
        console.log(msg);
    }
});
最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3