- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用此 api 返回与邮政编码匹配的地点
例如邮政编码 11233
http://postnummersok.se/api?q=11233
我用这样的用户输入值调用它,但结果无法解析,我该如何排除故障,它是否甚至得到回调?我的 firebug 显示没有 js 错误。
$('#zip').live("keyup",function () {
var zip = this.value.replace(/ /g,'');
if(zip.length > 4) {
var url = 'http://postnummersok.se/api?q=' + zip;
$.getJSON(url, function(data) {
$('#result').html(data);
});
} else {
$('#result').html('to short');
}
});
最佳答案
我假设您的代码所在的文档不在 http://postnummersok.se
上。如果不是,您将遇到 Same Origin Policy ,它(通常)不允许 ajax 请求跨源。
如果这是一项公开提供的服务,他们可能支持 JSON-P ,不受 SOP 约束。 jQuery 也支持它,因此它可能就像更改代码一样简单:
$.getJSON(url, function(data) {
$('#result').html(data);
});
到此
$.ajax({
url: url,
dataType: "jsonp",
success: function(data) {
$('#result').html(data);
}
});
更多内容请参见 $.ajax
文档。
更新:在评论另一个答案时注意到您正在动态创建查询字符串,但没有对参数进行编码。如果 zip
包含任何必须进行 URL 编码的字符,您的 URL 将变得困惑。每当创建查询字符串时,您都必须使用 encodeURIComponent
:
var url = 'http://postnummersok.se/api?q=' + encodeURIComponent(zip);
...或者只是将带有键/值对的对象传递给 jQuery,这将为您正确序列化它们。修改上面的 ajax 调用后,效果如下:
$.ajax({
url: 'http://postnummersok.se/api',
data: {q: zip},
dataType: "jsonp",
success: function(data) {
$('#result').html(data);
}
});
<小时/>
更新 2:我很好奇,是的,您可以使用此服务,并且它使用 JSON-P。来自 http://postnummersok.se/ :
API
Vi har ett rest-api tillgängligt för alla. Skicka din sökfråga till http://postnummersok.se/api med parametern q som antingen är ett postnummer eller en ort. Svaret kommer som ett JSON-objekt. Callback-parametern heter callback.
...Google 翻译为
API
We have a residual-api available to all. Send your query to http://postnummersok.se/api with parameter q which is either a postcode or place. The answer comes as a JSON object. The callback parameter named callback.
但是,服务已损坏并返回无效的 JSON-P 回复。如果您发送
http://postnummersok.se/api?callback=myCallback&q=721+06
...the response is
myCallback(["V\u00c4STER\u00c5S"])myCallback(null)
...它应该在哪里
myCallback(["V\u00c4STER\u00c5S"])
(末尾可能有 ;
。)
因此,如果我是您,我会向他们发送有关该错误的说明。
关于jquery - 获取 JSON 回调不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6610449/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!