我有一个非常简单的代码:
$.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-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');
?>对我来说,这就像是一种魔力!
https://stackoverflow.com/questions/11168378
复制相似问题