当我使用Appcache Manifest请求外部资源时,为什么jQuery会抛出错误?

前端之家收集整理的这篇文章主要介绍了当我使用Appcache Manifest请求外部资源时,为什么jQuery会抛出错误?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个使用.appcache清单的应用程序.一切正常,资源得到缓存:
  1. CACHE MANIFEST
  2.  
  3. CACHE:
  4. css/images/ajax-loader.gif
  5. [...]
  6.  
  7. NETWORK:
  8. http://docs.google.com/*
  9.  
  10. SETTINGS:
  11. prefer-online

现在,当我从http://docs.google.com请求CSV资源时,如下所示:

  1. $.get(url,function (data) {
  2. // do something with the data
  3. }).fail(function () {
  4. alert("There was an error in loading current data from the server.");
  5. });

即使我在线(在Chrome和FF上),请求也会失败.在使用Appcache之前,一切正常.

在拥有Appcache清单时请求外部资源的正确方法是什么?

解决方法

正如我在评论中提到的,问题不是(仅)jQuery,而是CORS. Google Docs缺乏对它的支持(“发布到网络”意味着下载,而不是从不同的URL请求资源,即来源.显然谷歌不想添加标题集Access-Control-Allow-Origin“* ”.

所以我所做的就是遵循这个有用的指南:https://webapps.stackexchange.com/questions/11864/how-can-i-retrieve-records-from-a-google-spreadsheet-in-json-formathttps://developers.google.com/gdata/samples/spreadsheet_sample(URL现在不是CSV而是JSONP,它也改为//spreadsheets.google.com/Feeds/list / […] / [… ] / public / values?alt = json-in-script和jQuery在调用自动添加callback = xxx:

  1. $.ajax({
  2. url : url,type : 'GET',dataType : 'jsonp',success : function (data) {
  3. for(var i in data.Feed.entry) {
  4. console.log(entry['gsx$' + 'actualColumnHeader'].$t);
  5. }
  6. },error : function () {
  7. alert('Failed');
  8. }
  9. });

这不是很好或干净的任何方式(Atom Feed而不是CSV或JSON只是为了解析它?严重吗?),但它适用于我.

猜你在找的jQuery相关文章