4

当返回的 JSON 对象不包含数据时,我遇到了 JSON AJAX 回调问题。我的代码如下:

$.ajax({
    type: "POST",
    url: "includes/get_menu_name.php",
    headers: {"cache-control": "no-cache"},
    data: data,
    success: function(html) {
        //alert(html);
        var app_data = "";
        if (html.MenuData != 0) {
            $.each( $.parseJSON(html).MenuData, function() {
                app_data += "<li data-short='"+this['dish_short']+"' data-desc='"+this['dish_desc']+"' data-dish_id='"+this['dish_id']+"'>"+this['dish_name']+"</li>";
            });
            $('.listbox').show();
            $('.nameslist').html(app_data);
            $('li').hover(function() {
                $(this).addClass('hover2');
            },function(){
                $(this).removeClass('hover2');
            });
            if (html == "") {
                $('.listbox').hide();
            }

            $('li').click(function() {
                //alert($('li', this).data('short'));
                $('.price').val("");
                var main_name = $(this, 'li').text();
                $('.main_name').val(main_name);
                //$('.price').val($(this).find('.ajaxid').text());
                if(main_name.length > 40) {
                    $('.short_name').val($(this).data('short'))
                } else {
                    $('.short_name').val(main_name);
                }
                if($(this).data('desc')!="") {
                    $('.dish_desc').val($(this).data('desc'));
                }
                var dish_id=$(this).data('dish_id');
                $('.main_name').data('dish_id', dish_id);
                $('.listbox').hide();
            });
        }
    }
});//end ajax

错误返回为:

TypeError:$.parseJSON(...) is null

我尝试了各种方法来检查回调中是否有数据,但似乎都没有。我对使用 JSON 非常陌生,并且想知道如果没有要返回的数据,是否应该通过 php 页面添加不同的回调,但是想知道是否有办法通过 javascript 执行此操作。

4

3 回答 3

2

$.ajaxpost将返回字符串格式的 HTML,你需要这样的东西!

success:function(html)
{
    if(html)
    {
        try
        {
            html = JSON.parse(html);
            if(html.MenuData)
            {
                // do something interesting
            }
            else
            {
                // failed
            }
        }
        catch(e)
        {
            // failed
        }
    }
    else
    {
        // failed because response is empty
    }
}
于 2013-03-15T09:04:31.630 回答
2

在这里您可以指定 dataType 用作 json

  $.ajax({
    type: 'POST',
    url: ajaxURL,
     data:data,
    dataType: 'json',
    success: function(data){
        JSON.parse(data);
    }

});

在服务器端脚本中,您必须使用 json_encode 函数对数据进行编码。

于 2013-03-15T09:39:00.533 回答
1

通过 ajax 获取 json 时,需要注意以下几点(以防它也发现了您的问题)

1) Content-Type Json 解析将在Content-type: application/json html 获取(含义Content-Type: text/html或等效项)需要手动将 json 解析为字符串时流畅地工作。

2) Jquery 版本 这应该不是问题,因为它已经从版本:1.5 (你可能使用最新的版本,1.9)开始消退了这是一个指向 json 相关错误的链接:http: //bugs.jquery.com/ticket /8108

对于 json 密集型编码,人们经常使用 jquery-json ( http://code.google.com/p/jquery-json/ ),它是简单 jquery 的包装器。您可能需要考虑修复是否不容易。

我希望它至少部分回答。谢谢..

于 2013-03-15T09:12:15.247 回答