>백엔드 개발 >PHP 튜토리얼 >내 WordPress Ajax 호출이 \'0\'을 반환하는 이유는 무엇입니까?

내 WordPress Ajax 호출이 \'0\'을 반환하는 이유는 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-03 00:49:29729검색

Why Does My WordPress Ajax Call Return

WordPress에서 Ajax 호출 문제 해결: 출력이 "0"인 이유

WordPress에서 Ajax 호출을 수행하는 것은 간단할 수 있지만 때로는 문제가 발생할 수 있습니다. 발생할 수 있습니다. 일반적인 문제 중 하나는 다른 값을 전달했음에도 불구하고 Ajax 호출이 출력으로 "0"을 반환하는 경우입니다.

이 문제는 WordPress 프런트엔드에 ajaxurl 변수가 없기 때문에 발생합니다. WordPress에서는 이 변수를 백엔드에서 정의하지만 Ajax 호출이 실행되는 프런트엔드에서는 그렇게 하지 않습니다.

해결책: JavaScript 파일 현지화

이 문제를 해결하려면 프런트엔드 코드에서 ajaxurl 변수를 정의해야 합니다. 이는 데이터를 현지화된 스크립트와 연결하는 wp_localize_script 함수를 사용하여 수행할 수 있습니다.

이를 수행하는 방법은 다음과 같습니다.

  1. JavaScript를 대기열에 추가하세요 파일:

    <code class="php">function my_enqueue() {
       wp_enqueue_script( 'ajax-script', get_template_directory_uri() . '/js/my-ajax-script.js', array('jquery') );
    }
    add_action( 'wp_enqueue_scripts', 'my_enqueue' );</code>
  2. 스크립트 현지화:

    <code class="php">wp_localize_script( 'ajax-script', 'my_ajax_object', array( 'ajax_url' => admin_url( 'admin-ajax.php' ) ) );</code>

이 코드는 ajaxurl을 포함하는 Ajax 스크립트의 my_ajax_object라는 전역 객체 변수.

  1. Ajax 호출에 ajaxurl 변수를 사용하세요.

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

my_ajax_object.ajax_url을 사용하여, 이제 올바른 WordPress 엔드포인트에 Ajax 호출을 하고 예상되는 결과를 받을 수 있습니다. 출력합니다.

위 내용은 내 WordPress Ajax 호출이 \'0\'을 반환하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.