requestCrossOrigin 静态方法

Future<String> requestCrossOrigin(
  1. String url, {
  2. String? method,
  3. String? sendData,
})

向指定的 URL 发起跨域请求。

此 API 提供了适用于 IE9 的 request 的子集。如果不需要 IE9 的跨域支持,则应使用 request

实现

static Future<String> requestCrossOrigin(String url,
    {String? method, String? sendData}) {
  if (supportsCrossOrigin) {
    return request(url, method: method, sendData: sendData).then((xhr) {
      return xhr.responseText!;
    });
  }
  var completer = new Completer<String>();
  if (method == null) {
    method = 'GET';
  }
  var xhr = JS('var', 'new XDomainRequest()');
  JS('', '#.open(#, #)', xhr, method, url);
  JS(
      '',
      '#.onload = #',
      xhr,
      convertDartClosureToJS((e) {
        var response = JS('String', '#.responseText', xhr);
        completer.complete(response as FutureOr<String>?);
      }, 1));
  JS(
      '',
      '#.onerror = #',
      xhr,
      convertDartClosureToJS((e) {
        completer.completeError(e);
      }, 1));

  // IE9 RTM - XDomainRequest issued requests may abort if all event handlers
  // not specified
  // http://social.msdn.microsoft.com/Forums/ie/en-US/30ef3add-767c-4436-b8a9-f1ca19b4812e/ie9-rtm-xdomainrequest-issued-requests-may-abort-if-all-event-handlers-not-specified
  JS('', '#.onprogress = {}', xhr);
  JS('', '#.ontimeout = {}', xhr);
  JS('', '#.timeout = Number.MAX_VALUE', xhr);

  if (sendData != null) {
    JS('', '#.send(#)', xhr, sendData);
  } else {
    JS('', '#.send()', xhr);
  }

  return completer.future;
}