首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >jQuery.ajax() -在IE9中返回未定义的数据

jQuery.ajax() -在IE9中返回未定义的数据
EN

Stack Overflow用户
提问于 2012-06-23 17:29:29
回答 3查看 8.1K关注 0票数 8

我有一个非常简单的代码:

代码语言:javascript
运行
复制
$.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中的开发人员工具,它显示了一个正常的响应,所以请求工作正常,响应也很好,但是变量是未定义的

响应头部:

代码语言:javascript
运行
复制
Response    HTTP/1.1 200 OK
Cache-Control   no-cache
Content-Type    text/html; charset: UTF-8
Pragma  no-cache

响应

代码语言:javascript
运行
复制
string(4) "test"
EN

回答 3

Stack Overflow用户

发布于 2013-04-03 21:07:09

我怀疑这就是你的问题:

代码语言:javascript
运行
复制
Content-Type    text/html; charset: UTF-8

这个值的格式不正确(字符集后面的“:”是错误的),IE9不喜欢它,而是默默地失败,而不是说一些有用的东西。试试这个:

代码语言:javascript
运行
复制
Content-Type:    text/html;charset=utf-8
票数 7
EN

Stack Overflow用户

发布于 2013-04-29 21:09:59

我尝试了所有方法来解决在IE浏览器上发布ajax的问题(例如,在jquery ajax对象中添加无缓存、dataType、configType等),但最终问题不在ajax/javascript中,而是在PHP文件中:对于IE浏览器,只有 PHP文件必须以下面的头开头

代码语言:javascript
运行
复制
header("Content-type: text/html; charset=utf-8");

因此,您必须通过显式地指示作为ajax调用结果获得的php页面的内容类型

例如,假设有一个名为one.html的html页面和一个名为two.php的php页面。

在one.html中将javascript设置为

代码语言:javascript
运行
复制
var url = 'two.php';
$.ajax({
url: url,
type: "POST",
success: function(response){
alert(response)
}
});

在two.php页面设置如下:

代码语言:javascript
运行
复制
<?php
header("Content-type: text/html; charset=utf-8");
echo ('stuff to do');
?>

对我来说,这就像是一种魔力!

票数 1
EN

Stack Overflow用户

发布于 2012-06-23 17:31:31

试试这个:

代码语言:javascript
运行
复制
$.ajax({
  cache: false,
  dataType: 'html',
  complete: function(data){
    console.log(data);
  },
  success: function(data){
    console.log(data);
  },
  url: 'http://follows.pl/pages/ajaxtest'
});

通知

在成功函数中

代码语言:javascript
运行
复制
 success: function (data, textStatus, jqXHR)

该对象是third参数。

你实际上是通过访问一个不存在的属性来响应数据的。

在完整函数中也是如此

代码语言:javascript
运行
复制
 complete: function (jqXHR, complete_textStatus)

这里的对象是first place!

你必须记住地点。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/11168378

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档