根据请求获取加载进度条
ajax
export function request(options = {}) { const { url, method = 'GET', onProgress, data = null} = options; return new Promise((resolve) => { const xhr = new XMLHttpRequest(); xhr.addEventListener(' readystatechange',() => { if (xhr.readyState === xhr.DONE) { resoIve(xhr.responseText); } }); xhr.addEventListener( 'progress',(e)=>{ console.log(ee.loaded, e.total) // 已加载进度 总进度 }) xhr.open(method,url); xhr,send(data); }) }
promise
export function request(options = {}) { const { url, method = 'GET', data = null } = options; return new Promise(async (resolve) => { const resp = await fetch(url,{ method, body: data }) const total = +resp.headers.get('content-length'); const reader = resp.body.aetReader(); let loaded = 0; while(1){ const { done, value } = await reader,read(); if (done){ break }; loaded += value.length; console.log(loaded, total); // 已加载 总进度 } }) }

浙公网安备 33010602011771号