The body read-only property of the Response interface is a ReadableStream of the body contents.


A ReadableStream, or else null for any Response object constructed with a null body property, or for any actual HTTP response that has no body.

Note: Current browsers don't actually conform to the spec requirement to set the body property to null for responses with no body (for example, responses to HEAD requests, or 204 No Content responses).


In our simple stream pump example we fetch an image, expose the response's stream using response.body, create a reader using ReadableStream.getReader(), then enqueue that stream's chunks into a second, custom readable stream — effectively creating an identical copy of the image.

const image = document.getElementById("target");

// Fetch the original image
  // Retrieve its body as ReadableStream
  .then((response) => response.body)
  .then((body) => {
    const reader = body.getReader();

    return new ReadableStream({
      start(controller) {
        return pump();

        function pump() {
          return{ done, value }) => {
            // When no more data needs to be consumed, close the stream
            if (done) {

            // Enqueue the next data chunk into our target stream
            return pump();
  .then((stream) => new Response(stream))
  .then((response) => response.blob())
  .then((blob) => URL.createObjectURL(blob))
  .then((url) => console.log((image.src = url)))
  .catch((err) => console.error(err));


Fetch Standard
# ref-for-dom-body-body①

Browser compatibility

BCD tables only load in the browser

See also