本文整理匯總了TypeScript中spica/promise.AtomicPromise.race方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript AtomicPromise.race方法的具體用法?TypeScript AtomicPromise.race怎麽用?TypeScript AtomicPromise.race使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類spica/promise.AtomicPromise
的用法示例。
在下文中一共展示了AtomicPromise.race方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: wait
function wait(el: HTMLElement): AtomicPromise<Event> {
return AtomicPromise.race([
new AtomicPromise<Event>(resolve => void once(el, 'load', resolve)),
new AtomicPromise<Event>(resolve => void once(el, 'abort', resolve)),
new AtomicPromise<Event>(resolve => void once(el, 'error', resolve)),
]);
}
示例2: fetch
async function fetch(
script: HTMLScriptElement,
timeout: number,
): Promise<Either<Error, FetchData>> {
if (!script.hasAttribute('src')) return Right<FetchData>([script, script.text]);
if (script.type.toLowerCase() === 'module') return Right<FetchData>([script, '']);
return AtomicPromise.race([
window.fetch(script.src, {
headers: new Headers({
Accept: 'application/javascript',
}),
integrity: script.integrity,
}),
wait(timeout).then(() => AtomicPromise.reject(new Error(`${script.src}: Timeout.`))),
])
.then(
async res =>
res.ok
? Right<FetchData>([script, await res.text()])
: script.matches('[src][async]')
? retry(script)
.then(
() => Right<FetchData>([script, '']),
() => Left(new Error(`${script.src}: ${res.statusText}`)))
: Left(new Error(res.statusText)),
(error: Error) => Left(error));
}