This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.
Secure context: This feature is available only in secure contexts (HTTPS), in some or all supporting browsers.
The summarizeStreaming() method of the Summarizer interface generates a new summary as a ReadableStream.
summarizeStreaming(input) summarizeStreaming(input, options)
inputA string representing the text to be summarized.
options OptionalAn object specifying configuration options for the summarizeStreaming() operation. Possible values include:
contextA string describing the context the input text is being used in, which helps the Summarizer generate a more suitable summary.
signalAn AbortSignal object instance, which allows the summarizeStreaming() operation to be aborted via the associated AbortController.
A ReadableStream containing the generated summary.
InvalidStateError DOMException
Thrown if the current Document is not active.
NotAllowedError DOMException
Thrown if usage of the Summarizer API is blocked by a summarizer Permissions-Policy.
NotReadableError DOMException
Thrown if the output summary was filtered by the user agent, for example because it was detected to be harmful, inaccurate, or nonsensical.
NotSupportedError DOMException
Thrown if the provided context is not in language the Summarizer supports.
QuotaExceededErrorThrown if the summarize operation exceeds the available inputQuota.
UnknownError DOMException
Thrown if the summarizeStreaming() call failed for any other reason, or a reason the user agent did not wish to disclose.
summarizeStreaming() usageconst summarizer = await Summarizer.create({
sharedContext:
"A general summary to help a user decide if the text is worth reading",
type: "tldr",
length: "short",
});
const stream = summarizer.summarizeStreaming(myTextString);
let summary = "";
for await (const chunk of stream) {
summary += chunk;
}
console.log("Stream complete");
summaryOutput.textContent = summary;
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
summarizeStreaming |
138Availability may be subject to geographical restrictions. |
138 | No | 122Availability may be subject to geographical restrictions. |
No | No | No | No | No | No | No | No |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/Summarizer/summarizeStreaming