jquery 为什么 AJAX json脚本返回额外的0(零)

nvbavucw  于 2023-08-04  发布在  jQuery
关注(0)|答案(3)|浏览(153)

我在WordPress中有一个 AJAX 函数,它调用一个PHP函数来返回数据库中一个临时记录的值。
当我使用jQuery调用函数时,我会收到结果,但它总是在值后面附加一个额外的0(零)。
下面是我的jQuery函数:

(function($) {
    $(document).ready( function() {

        var AdvancedDashboardWidget = function(element, options)
        {
            var ele = $(element);
            var settings = $.extend({
                action: '',
                service: '',
                countof: '',
                query:   '',
                callback:''
            }, options || {});
            this.count=0;
            var url='';
            switch(settings.service)
            {
                case 'facebook':
                    if(settings.countof=='likes' || settings.countof=='talks')
                    {
                        ajaxCall(action,ele,settings);  
                    }
            }
        };

    var ajaxCall = function(action,ele,settings){
        opts = {
            url: ajaxurl, // ajaxurl is defined by WordPress and points to /wp-admin/admin-ajax.php
            type: 'POST',
            async: true,
            cache: false,
            dataType: 'json',
            data:{
                action: settings.action // Tell WordPress how to handle this ajax request
            },
            success:function(response) {
                //alert(response);
                ele.html(response);
                return; 
            },
            error: function(xhr,textStatus,e) {  // This can be expanded to provide more information
                alert(e);
                //alert('There was an error');
                return; 
            }
        };
        $.ajax(opts);
    };

        $.fn.advanceddashboardwidget = function(options)
        {
            return this.each(function()
            {
                var element = $(this);

                // Return early if this element already has a plugin instance
                if (element.data('advanceddashboardwidget')) return;

                // pass options to plugin constructor
                var advanceddashboardwidget = new AdvancedDashboardWidget(this, options);

                // Store plugin object in this element's data
                element.data('advanceddashboardwidget', advanceddashboardwidget);
            });
        };

    });
})(jQuery);

字符串
还有更多的帮助函数,但这是与WordPress通信并返回PHP函数值的主要jQuery函数。
问题是,如果返回值为“99”,例如,它将返回为“990”。

以下是jQuery调用的PHP函数:

/**
* Get Facebook Likes
*/

public function get_facebook_likes(){

    echo 99;
}


如果我将上面的代码改为return 99;,我将收到纯0

ryevplcw

ryevplcw1#

您的函数应该使用wp_send_json将结果编码为JSON并将其发送回 AJAX 请求处理程序。这也将停止任何后续PHP的执行,因此不需要使用exit或die。
因此,对于您的特定示例,您可以用途:

/**
* Get Facebook Likes
*/

public function get_facebook_likes(){
   wp_send_json(99);
}

字符串

2nbm6dog

2nbm6dog2#

这是一个老问题,但我会回答这个问题。wp_send_json()函数可能会有所帮助,但并不总是如此。可能有一些时候你不能使用这个功能。就像,当你通过 AJAX 加载帖子时,你会得到一些模板部分,你可以使用该函数。这就是为什么WordPress文档建议使用die()函数。
所以最后,你的php函数应该看起来像这样:

/**
* Get Facebook Likes
*/

public function get_facebook_likes() {
   echo 99;
   die();
}

字符串

ioekq8ef

ioekq8ef3#

使用Firebug并查看发送和接收的实际网络数据。确定错误是来自JavaScript端还是PHP端。复制网络请求并将其粘贴到单独的浏览器窗口中以查看原始结果。如果是PHP,那就继续吧。如果是JavaScript在做什么,请告诉我们。

相关问题