0

jquery 版本:http ://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js

    $.ajax({
        url: CI_ROOT + current_page + '/get_results' ,
        type: 'post',
        data: { 'primary_key': primary_key, 'search_category':search_category, 'sub_category': sub_category ,'search_page':search_page, 'search_order': search_order, 'project_type': project_type},
        beforeSend: function(){
            $('.browse-list').html(spinner);
            $('.page-number-nav').html('');
        },          
        success: function(r){
            var response_obj = jQuery.parseJSON(r.responseText);

            $('.browse-list').html('');

            if (response_obj.status == 'SUCCESS')
            {               
                $('#sort_menu').hide();
                $('#sort_type').hide();

                if ((response_obj.results != 'No results') && (search_category != 'group') && (search_category == 'title' || (primary_key > 0)))
                {
                    $('#sort_menu').show(); 
                    $('#sort_type').show();             
                }

                $('.browse-list').html(response_obj.results);
                $('.page-number-nav').html(response_obj.pagination);
            }
        }
    }); 

if (r.responseText == undefined){alert('Empty');} 对于 IE 8 和 9 返回 Empty,但适用于 IE10 和所有其他浏览器

我已经阅读并尝试了这里的每一篇文章,我发现可能是相关的,无法理解为什么这只会对这两个浏览器造成轰炸,以及要检查的内容

蒂亚!

4

1 回答 1

0

dataType尝试像这样给你 ajax 调用:

dataType: 'json'

所以它知道你期待什么样的数据。您还应该content type从服务器返回响应标头中的application/json- 您的json_encode方法只是将您的对象转换为 JSON,但显然没有应用正确的标头(参考php.net

您需要添加:

header('Content-Type: application/json;charset=utf-8');

明确声明后,dataType应该不需要jQuery.ParseJSON,因为它会在调用success处理程序之前对其进行转换,因此参数r将是您期望的 JSON :)

还只是一个注释(正如 OP 发现的那样),header函数调用需要在您的json_encode调用之前

于 2013-09-26T06:46:58.927 回答