我有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源?
答案 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);
}
希望这有帮助