WordPress中的Qtip和ajax - 操作不起作用

时间:2017-02-09 08:57:58

标签: php jquery ajax wordpress qtip

我试图在我的Wordpress网站中集成QTip jquery工具提示,使用Ajax触发工具提示,其中包含从自定义数据库表中提取的一些信息。

我已将enque和动作内容添加到我的function.php:

function enqueue_scripts_styles_init() {
  wp_enqueue_style('qtip', 'http://www.my-site.com/wp-content/themes/my-theme/qtip/jquery.qtip.min.css', null, false, false);
  wp_enqueue_script('qtip', 'http://www.my-site.com/wp-content/themes/my-theme/qtip/jquery.qtip.min.js', array('jquery'), false, true);
  wp_enqueue_script('qtipCall', 'http://www.my-site.com/wp-content/themes/my-theme/qtip/qtipcall.js', array('jquery', 'qtip'), false, true);
  wp_localize_script( 'qtipCall', 'ajax_object', array( 'ajaxurl' => admin_url( 'admin-ajax.php' ) ) );
}
add_action('init', 'enqueue_scripts_styles_init');

function ajax_action_stuff() {
  global $wpdb;
  $hero = $_POST['who'];
  $results = $wpdb->get_row( $wpdb->prepare ('SELECT * FROM wp_herotable WHERE Name = %s', $hero) );
  $hero_bio = $results->Bio;
  echo $hero_bio;
  wp_die();
}
add_action( 'wp_ajax_ajax_action', 'ajax_action_stuff' );
add_action( 'wp_ajax_nopriv_ajax_action', 'ajax_action_stuff' );

这是我的qtipcall.js:

jQuery(document).ready(function( $ ) {
$('[tip-hero').each(function() {
    $(this).qtip({
        content: {
            text: function(event, api) {
                $.ajax({
                url: ajax_object.ajaxurl,
                type: 'POST',
                action: 'ajax_action',
                data: {who: $(this).attr("tip-hero")},
            })
                .then(function(content) {
                    // Set the tooltip content upon successful retrieval
                    api.set('content.text', content);
                }, function(xhr, status, error) {
                    // Upon failure... set the tooltip content to error
                    api.set('content.text', status + ': ' + error);
                });

                return 'Loading...'; // Set some initial text
            }

        },

        style: { 
        classes: 'qtip-dark qtip-rounded qtip-shadow'
        }
    });
});

});

最后,我的页面:

<a hfer="#" tip-hero="Joan of Arc">Joan of Arc</a>

结果是一个很酷的工具提示,里面有一个0!我检查了admin-ajax.php,零来自:

// Require an action parameter
if ( empty( $_REQUEST['action'] ) )
die( '0' );

所以我认为我的行动电话有问题,但我真的无法理解它是什么。

任何帮助将不胜感激。

感谢。

1 个答案:

答案 0 :(得分:0)

更改您的ajax以发送操作值:

   data: {who: $(this).attr("tip-hero"),action: 'ajax_action'},