0

根据 caniuse.comopera.com的说法,Opera Mini 不支持 CORS。有解决方法吗?我可以从/向不同域或至少向 AngularJS 中的子域发出 AJAX 请求吗?

4

1 回答 1

1

使用以下解决方法之一:

  • window.name可用于跨域共享数据。例如:

    window.name=window.StackExchange; window.location="http://www.example.com"; console.log(window.name);
    
  • DOM 3 级加载和保存

任何解决方案都有其缺陷,但除了 Opera 之外,没有其他解决方案允许data:URI 不在同一个域中。一旦parseURI可以结合执行data:URI,可能性是无穷无尽的——而且很难确定有效载荷的来源和内容。

data:URI与通过 XHR 加载原始页面的 HTML 文档一起使用

解析URI

从 URI 引用 [IETF RFC 2396] 标识的位置解析 XML 文档。如果 URI 包含片段标识符(参见 [IETF RFC 2396] 中的第 4.1 节),则本规范未定义该行为,本规范的未来版本可能会定义该行为。

  function loadDataForVersion(core_version)
    {
    var features_doc = document.implementation.createLSParser(DOMImplementationLS.MODE_SYNCHRONOUS, "").parseURI("features."+core_version+".xml");
    var feature_nodes = features_doc.evaluate("//feature", features_doc, null, XPathResult.ORDERED_NODE_ITERATOR_TYPE, null);
    var feature_node;
    while (feature_node = feature_nodes.iterateNext())
      {
      addFeatureNode(features_doc, feature_node, core_version);
      }
    }

异步LSParser对象也应该实现 events::EventTarget 接口,以便可以在异步LSParser对象上注册事件侦听器。

异步LSParser对象支持的事件有:

加载

LSParser完成加载文档。另见LSLoadEvent接口的定义。

进步

LSParser信号随着数据的解析而进展。

本规范并未尝试准确定义何时应分派进度事件。故意将其保留为依赖于实现。下面是应用程序如何分派进度事件的一个示例:一旦解析器开始接收数据,就会分派一个进度事件以指示解析开始。从那里开始,每接收和处理 4096 个字节的数据就会调度一个进度事件。不过,这只是一个示例,实现可以选择在解析时随时分派进度事件,或者根本不分派它们。

使用 CSSHttpRequest.get(url, callback) 函数调用请求:

CSSHttpRequest.get(
        "http://www.nb.io/hacks/csshttprequest/hello-world/",
        function(response) { alert(response); }
    );

数据在服务器上被编码为 URI 编码的 2KB 块,并通过修改后的about:URI方案序列化为 CSS @import 规则。响应被解码并作为字符串返回给回调函数

参考

于 2016-12-08T16:00:43.403 回答