jQuery $ .get返回完整的Object vs我正常需要的东西

时间:2011-10-17 14:06:43

标签: javascript jquery json getjson

这是我的代码:

var source;
source = $.getJSON(url, function(json) {
  return console.log(json);
});

以上是返回完整的jQuery对象与我请求的JSON。响应看起来像这样:

abort: function ( statusText ) {
always: function () {
complete: function () {
done: function () {
error: function () {
fail: function () {
getAllResponseHeaders: function () {
getResponseHeader: function ( key ) {
isRejected: function () {
isResolved: function () {
overrideMimeType: function ( type ) {
pipe: function ( fnDone, fnFail ) {
promise: function ( obj ) {
readyState: 4
responseText: "{'Hello':'World'}"
setRequestHeader: function ( name, value ) {
status: 200
statusCode: function ( map ) {
statusText: "OK"
success: function () {
then: function ( doneCallbacks, failCallbacks ) {
__proto__: Object

任何人都知道我做错了什么?我现在已经处理了几个小时了:(

3 个答案:

答案 0 :(得分:6)

AJAX是异步的,source不能与您请求的JSON相等,因为它尚不可用。 jQuery.getJSON会返回它创建的jqXHR对象,以处理请求然后逃跑并检索回复。

$.getJSON(url, function(json) {
  // deal with response  here
});

当响应可用时(稍后),将执行回调(您正在传递的函数),因此您可以通过第一个参数(您可以)访问其中的响应我称之为json)。

您可以尝试以下方法来看到这一点:

console.log('1');

$.getJSON(url, function(json) {
    console.log('2');
});

console.log('3');

您将看到您的控制台将读取1,3,然后在一瞬间读取(即执行HTTP请求的时间),2;这显示getJSON响应在没有完成的情况下返回,脚本继续执行,然后在稍后的某段时间调用回调

答案 1 :(得分:0)

尝试这样做:

var source;
source = $.get(url, function(data) {
  return alert($.parseJSON(data));
});

答案 2 :(得分:0)

从jQuery 1.5开始,该方法返回一个jqXHR对象(你所看到的)。有关详细信息,请参阅文档here

您可以看到所需的JSON实际上在responseText变量中。所以它应该是source.responseText