Skip to content

Instantly share code, notes, and snippets.

@amir-ba
Forked from jfsiii/fetch-chunked.js
Created November 17, 2022 15:20
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save amir-ba/d2ba1fb61222da52ba913f65accaa99d to your computer and use it in GitHub Desktop.
Save amir-ba/d2ba1fb61222da52ba913f65accaa99d to your computer and use it in GitHub Desktop.
Quick example of using fetch to parse a chunked response
var chunkedUrl = 'https://jigsaw.w3.org/HTTP/ChunkedScript';
fetch(chunkedUrl)
.then(processChunkedResponse)
.then(onChunkedResponseComplete)
.catch(onChunkedResponseError)
;
function onChunkedResponseComplete(result) {
console.log('all done!', result)
}
function onChunkedResponseError(err) {
console.error(err)
}
function processChunkedResponse(response) {
var text = '';
var reader = response.body.getReader()
var decoder = new TextDecoder();
return readChunk();
function readChunk() {
return reader.read().then(appendChunks);
}
function appendChunks(result) {
var chunk = decoder.decode(result.value || new Uint8Array, {stream: !result.done});
console.log('got chunk of', chunk.length, 'bytes')
text += chunk;
console.log('text so far is', text.length, 'bytes\n');
if (result.done) {
console.log('returning')
return text;
} else {
console.log('recursing')
return readChunk();
}
}
}
got chunk of 32768 bytes
text so far is 32768 bytes
recursing
got chunk of 32768 bytes
text so far is 65536 bytes
recursing
got chunk of 6664 bytes
text so far is 72200 bytes
recursing
got chunk of 0 bytes
text so far is 72200 bytes
returning
all done! This output will be chunked encoded by the server, if your client is HTTP/1.1
<snip>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment