加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 在WordPress插件中使用AJAX

发布时间:2020-12-13 13:01:45 所属栏目:PHP教程 来源:网络整理
导读:我正在尝试创建一个基于 AJAX的WordPress示例插件.我阅读了一个教程并做了一个插件,但它没有用.我是AJAX的新手.这是我试过的代码: ?phpclass ajaxtest { function ajaxcontact() { ? div id="feedback"/div form name="myform" id="myform" li label for fn
我正在尝试创建一个基于 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','addcontact')); // not really needed
add_shortcode('cform','ajaxcontact'));

我用它作为短代码,但我没有得到输出.怎么了?

WordPress环境

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

请看看:

> wp_register_script();功能
> wp_enqueue_scripts勾
> wp_enqueue_script();功能
> wp_localize_script();功能

在主插件文件中,添加这些.

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调用触发的函数.
记住后缀:

> wp_ajax(仅限注册用户或管理面板操作的功能)
> wp_ajax_nopriv(允许无特权用户的功能)

这些后缀加上操作组成了您的操作名称:

wp_ajax_myaction或wp_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
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读