在WordPress插件中使用AJAX

时间:2013-07-25 10:45:02

标签: php jquery wordpress

我正在尝试创建一个基于AJAX的WordPress示例插件。我阅读了一个教程并做了一个插件,但它没有用。我是AJAX的新手。这是我试过的代码:

<?php
class ajaxtest {

    function ajaxcontact() {
        ?>
        <div id="feedback"></div>
        <form name="myform" id="myform">
            <li>
                <label for fname>First Name</label><input type="text" id="fname" name="fname" value=""/>
            </li>
            <li>
                <label for lname>Last Name</label><input type="text" id="lname" name="lname" value=""/>
            </li>
            <input type="submit" value="Submit" id="submit" name="submit"/>
        </form>
        <script type="text/javascript">
            jQuery('#submit').submit(ajaxSubmit);

            function ajaxSubmit() {

                var newcontact = jQuery(this).serialize();

                jQuery.ajax({
                    type: "POST",
                    url: "/wp-admin/admin-ajax.php",
                    data: newcontact,
                    success: function(data) {
                        jQuery("#feedback").html(data);
                    }
                });

                return false;
            }
        </script>
        <?php
    }

    function addcontact() {
        $fname = $_POST['fname'];
        if ($fname != "") {
            echo "Your Data is" . $fname;
        } else {
            echo "Data you Entered is wrong";
        }

        die();
    }

}

function jquery_add_to_contact() {
    wp_enqueue_script('jquery');  // Enqueue jQuery that's already built into WordPress
}

add_action('wp_enqueue_scripts', 'jquery_add_to_contact');
add_action('wp_ajax_addcontact', array('ajaxtest', 'addcontact'));
add_action('wp_ajax_nopriv_addcontact', array('ajaxtest', 'addcontact')); // not really needed
add_shortcode('cform', array('ajaxtest', 'ajaxcontact'));

我用它作为短代码,但我没有得到输出。这是什么错误?

2 个答案:

答案 0 :(得分:28)

WordPress环境

首先,为了完成这项任务,建议注册然后将jQuery脚本排队,将请求推送到服务器。这些操作将挂钩在wp_enqueue_scripts动作挂钩中。在同一个钩子中,您应该将wp_localize_script用于包含任意JavaScript。通过这种方式,前端将有一个JS对象。该对象继续使用jQuery句柄使用的正确url。

请看一下:

  1. wp_register_script();功能
  2. wp_enqueue_scripts hook
  3. wp_enqueue_script();功能
  4. wp_localize_script();功能
  5. 在主插件文件中,添加这些。

    add_action( 'wp_enqueue_scripts', 'so_enqueue_scripts' );
    function so_enqueue_scripts(){
      wp_register_script( 
        'ajaxHandle', 
        plugins_url('PATH TO YOUR SCRIPT FILE/jquery.ajax.js', __FILE__), 
        array(), 
        false, 
        true 
      );
      wp_enqueue_script( 'ajaxHandle' );
      wp_localize_script( 
        'ajaxHandle', 
        'ajax_object', 
        array( 'ajaxurl' => admin_url( 'admin-ajax.php' ) ) 
      );
    }
    

    档案:jquery.ajax.js

    此文件进行AJAX调用。

    jQuery(document).ready( function($){
      // Some event will trigger the ajax call, you can push whatever data to the server, 
      // simply passing it to the "data" object in ajax call
      $.ajax({
        url: ajax_object.ajaxurl, // this is the object instantiated in wp_localize_script function
        type: 'POST',
        data:{ 
          action: 'myaction', // this is the function in your functions.php that will be triggered
          name: 'John',
          age: '38'
        },
        success: function( data ){
          //Do something with the result from server
          console.log( data );
        }
      });
    });
    

    还要在插件主文件中添加以下代码。

    最后,在你的functions.php文件中,应该有你的AJAX调用触发的函数。 记住后缀:

    1. wp_ajax(仅限注册用户或管理面板操作的功能)
    2. wp_ajax_nopriv(允许无权限用户的功能)
    3. 这些后缀加上操作组成了您的操作名称:

      wp_ajax_myactionwp_ajax_nopriv_myaction

      add_action( "wp_ajax_myaction", "so_wp_ajax_function" );
      add_action( "wp_ajax_nopriv_myaction", "so_wp_ajax_function" );
      function so_wp_ajax_function(){
        //DO whatever you want with data posted
        //To send back a response you have to echo the result!
        echo $_POST['name'];
        echo $_POST['age'];
        wp_die(); // ajax call must die to avoid trailing 0 in your response
      }
      

答案 1 :(得分:5)

您需要在AJAX调用中添加“操作”。

jQuery.ajax({
  type: "POST",
  url: "/wp-admin/admin-ajax.php",
  data: newcontact,
  action: 'addcontact',
  success: function(data) {
    jQuery("#feedback").html(data);
  }
});

该值应与wp_ajax的add_action挂钩相同。 e.g。

add_action( wp_action_{action_value}, 'myfunc' );

这允许WordPress知道在进行AJAX调用时要运行的函数。

This Codex page has some useful infothis article describes如何更好地优化您的代码。