如何为jQuery.ajax使用不同的json解析器?

时间:2013-11-10 21:15:22

标签: javascript jquery ajax json

我有json数据"标记"值(来自jsonp来源):

{"foo": "@duration:8542"}

我可以通过将函数作为第二个参数传递给JSON.parse来实时解析:

dk.json = {
    parse: function (s) {
        return JSON.parse(s, function (key, val) {
            if (typeof val === 'string' && val[0] === '@') {
                var colonpos = val.indexOf(':');
                if (colonpos > 1) {
                    var tag = val.slice(0, colonpos + 1);
                    switch (tag) {
                        case dk.Date.tag:       return dk.Date.create(val);
                        case dk.Duration.tag:   return dk.Duration.create(val);
                    }
                }
            }
            return val;
        });
    },
    //...
};

但是如何将此解析功能插入jQuery.ajax()?比这更明智的事情:

success: function (data) {
    data = dk.json.parse(JSON.stringify(data));
    ...

dataFilter,特别是converters看起来很有希望:

$.ajax({
    dataType: 'jsonp',
    converters: {
        'text json': dk.json.parse
    },
    // ...
});

但根本没有调用(调用dataFilter,但数据参数设置为undefined)。

我哪里错了?

[编辑:]

我知道我可以编写遍历jQuery返回的JSON对象的遍历函数,例如:

function untag(val) {
    if (typeof val === 'string' && val[0] === '@') {
        var colonpos = val.indexOf(':');
        if (colonpos > 1) {
            var tag = val.slice(0, colonpos + 1);
            switch (tag) {
                case dk.Date.tag:     return dk.Date.create(val);
                case dk.Duration.tag: return dk.Duration.create(val);
            }
        }
    }
    return val;
}

var untag_json = function (jsonobj) {
    var _traverse = function _traverse(obj, result) {
        var value;
        for (var attr in obj) {
            value = obj[attr];
            if (value && typeof value === 'object') {
                result[attr] = _traverse(value, {});
            } else {
                result[attr] = untag(value);
            }
        }
        return result;
    };

    return _traverse(jsonobj, {});
};

然后在success处理程序中调用它:

success: function (data) {
    data = untag_json(data);
    ...

但这似乎是很多不必要的工作..是否无法使用converters参数$.ajax来访问未解析的(即文本)json源?

2 个答案:

答案 0 :(得分:1)

在JSONP请求(src)中实际上没有任何JSON解析,这看起来很直观。发生的事情是从JSONP端点返回的字符串被评估为JavaScript(引用在DOM中定义(或动态添加)的函数,生成JSONP请求,如下所示:

_callback({'foo':'@duration:8524'});

如果你想使用你的函数,你需要让端点返回一个像这样的字符串:

_callback("{'foo':'@duration:8524'}");

然后在JSONP回调中你可以调用JSON.parse()。 JSON解析是一种处理JSON的相当安全的方法,所以如果这更容易推理,那么这将是一个很好的方法。

答案 1 :(得分:0)

您需要在服务器端的响应中设置此头应用程序/ json然后您可以简单地设置dataType:json或dataType:jsonp然后您将不需要字符串化或解析json。然后,您只需从json获取对象,属性或数组。

例如:在php中我们使用

$json_string = "{"foo": "@duration:8542"}";
$json = json_decode($json_string); 
$foo = $json->foo;
echo $foo;//prints @duration:8542

在jquery中你可以这样做:

sucess:function(response) {
  var foo = response.foo;
  console.log(foo);
}

希望这有帮助