$http.json()是如何工作的
How does $http.jsonp() work
以下是.json
文件的示例:
[
{
"name":"Jon Skeets"
},
{
"name":"Bill Joy"
}
]
如果这个json文件被获取为:
$http.jsonp(pathToFile).then() {
...
}
它返回一个404。pathToFile
没有问题,我已经用curl, wget and the browser
验证过了。但是问题在于jsonp()
必须获取具有上述结构的.json
文件。$http.get()
可以解析具有上述结构的.json
文件。但JSONP
不能。它需要一个顶级的字典,而不是一个数组。
为了证明这一点,我创建了这个燃烧基地:https://blazing-fire-6512.firebaseapp.com/name.json
在浏览器或wget中获取链接,它就可以工作了。尝试在这里用Angular获取它,它会返回404请求失败。
Firebase主机不支持JSONP。它不处理用于评估跨源的JSONP回调的callback
参数。
假设您将此JSON存储在URL http://example.com/name.json
:
{ "name":"Jon Skeets" }
如果您访问URL http://example.com/name.json
,那么您会得到确切的JSON。这正是$http.get
所做的。
当服务器支持JSONP时,它接受callback
参数。在这种情况下,URL最终为http://example.com/name.json?callback=displayName
,响应为:
displayName('{ "name":"Jon Skeets" }');
这允许跨源检索JSON数据,这就是JSONP存在的全部原因。
Firebase的动态数据服务器支持JSON。Firebase主机没有。
一些可能的解决方案:
- 如果您将JSON文件和应用程序存储在Firebase主机上,则只需使用
$http.get
即可 - 由于您控制JSON文件,您也可以简单地将函数名放在name.JSON中
- 将JSON文件存储在支持JSONP的主机上。我经常把它们放在Github Gists中
- 将数据结构存储在Firebase分层数据库中,而不是存储在其托管服务器上
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- 最大高度转换不;不工作,工作缓慢
- Gulp-rev:不是第一次工作,而是在第一次工作之后工作
- 在JavaScript中的类中,push和concat的工作方式有何不同
- JQuery - Ajax: encodeUriComponent不工作(EncodeUri工作)