requestCrossOrigin 静态方法
向指定的 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;
}