我正在尝试向 Google API 发出 ajax 请求,以获取当前汇率的 JSON 数据。
到目前为止我的代码:
$.ajax({
url: "http://www.google.com/ig/calculator?hl=de&q=1USD=?EUR"
}).done( function ( data ) {
var obj = $.parseJSON( data )
alert( data.rhs );
});
google api 的链接是http://www.google.com/ig/calculator?hl=de&q=1USD=?EUR
我的问题是我的代码没有触发该done
功能。
我知道缺少一些东西,也许是一些参数?
更新
这是我在某处找到的新代码:
function forex(val, from, to, callback) {
$.ajax({
url: 'http://www.google.com/ig/calculator?hl=en&q='+val+from+'%3D%3F'+to,
type: 'GET',
datatype: 'string',
success: function(data) {
var json = eval("(" + data+ ")"), output;
if (typeof json == 'object' && json.rhs) {
output = json.rhs.match(/[0-9.\s]+/ig);
output = output[0] || false;
} else {
output = data.match(/[0-9.\s]+/ig);
output = output[1] || false;
}
output = (output !== false) ? Number(output.replace(/\s/,'')) : output;
callback(output);
},
error: function() {
callback(false);
}
});
}
function output(data) {
alert( data );
$('#show_product_price_api').val(data);
}
但是当我使用这个功能时:
forex(100, 'USD', 'EUR', output);
要触发事件,我会收到“FALSE”回调
知道为什么调用此错误函数吗?
更新 2
我认为这是一个跨域问题,有人对使用 jsonp 有任何建议吗?