我有一个非常简单的代码:
$.ajax({
  cache: false,
  dataType: 'html',
  complete: function(jqXHR){
    console.log(jqXHR.responseText);
  },
  success: function(data){
    console.log(data);
  },
  url: 'http://follows.pl/pages/ajaxtest'
});它在ff、chrome和IE8中返回一些文本,但在IE9中它显示两次"undefined“。
我研究了IE9中的开发人员工具,它显示了一个正常的响应,所以请求工作正常,响应也很好,但是变量是未定义的
响应头部:
Response    HTTP/1.1 200 OK
Cache-Control   no-cache
Content-Type    text/html; charset: UTF-8
Pragma  no-cache响应
string(4) "test"发布于 2013-04-03 21:07:09
我怀疑这就是你的问题:
Content-Type    text/html; charset: UTF-8这个值的格式不正确(字符集后面的“:”是错误的),IE9不喜欢它,而是默默地失败,而不是说一些有用的东西。试试这个:
Content-Type:    text/html;charset=utf-8发布于 2013-04-29 21:09:59
我尝试了所有方法来解决在IE浏览器上发布ajax的问题(例如,在jquery ajax对象中添加无缓存、dataType、configType等),但最终问题不在ajax/javascript中,而是在PHP文件中:对于IE浏览器,只有 PHP文件必须以下面的头开头
header("Content-type: text/html; charset=utf-8");因此,您必须通过显式地指示作为ajax调用结果获得的php页面的内容类型。
例如,假设有一个名为one.html的html页面和一个名为two.php的php页面。
在one.html中将javascript设置为
var url = 'two.php';
$.ajax({
url: url,
type: "POST",
success: function(response){
alert(response)
}
});在two.php页面设置如下:
<?php
header("Content-type: text/html; charset=utf-8");
echo ('stuff to do');
?>对我来说,这就像是一种魔力!
发布于 2012-06-23 17:31:31
试试这个:
$.ajax({
  cache: false,
  dataType: 'html',
  complete: function(data){
    console.log(data);
  },
  success: function(data){
    console.log(data);
  },
  url: 'http://follows.pl/pages/ajaxtest'
});通知
在成功函数中
 success: function (data, textStatus, jqXHR)该对象是third参数。
你实际上是通过访问一个不存在的属性来响应数据的。
在完整函数中也是如此
 complete: function (jqXHR, complete_textStatus)这里的对象是first place!
你必须记住地点。
https://stackoverflow.com/questions/11168378
复制相似问题