
Security News
n8n Tops 2025 JavaScript Rising Stars as Workflow Platforms Gain Momentum
n8n led JavaScript Rising Stars 2025 by a wide margin, with workflow platforms seeing the largest growth across categories.
vue-ssr-html-stream
Advanced tools
Note: this package is used internally by vue-server-renderer >= 2.2.0 via the
templateoption.
const HTMLStream = require('vue-ssr-html-stream')
const htmlStream = new HTMLStream({
template, // string
context, // ?Object
outletPlaceholder // ?string, defaults to <!--vue-ssr-outlet-->
})
// pipe it
renderStream
.pipe(htmlStream)
.pipe(responseStream)
The template option is a string of the HTML page template. It must contain a special string which serves as the placeholder for your app's server-rendered content. The default placeholder string is <!--vue-ssr-outlet--> - you can configure it with the outletPlaceholder option.
The context option should be the same context object passed to bundleRenderer.renderToStream(). The transform will check for a few special properties on the context when the source render stream starts emitting data:
context.head: any head markup that should be injected into the head of the page.
context.styles: any inline CSS that should be injected into the head of the page. Note that vue-loader 10.2.0+ (which uses vue-style-loader 2.0) will automatically populate this property with styles used in rendered components.
context.state: initial Vuex store state that should be inlined in the page as window.__INITIAL_STATE__. The inlined JSON is automatically sanitized with serialize-javascript.
beforeStart eventThe stream emits a special event: beforeStart. An example use case would be generating context.head using info injected by vue-meta:
htmlStream.on('beforeStart', () => {
const meta = context.meta.inject()
context.head = (context.head || '') + meta.title.text()
})
const HTMLStream = require('vue-ssr-html-stream')
const template = require('fs').readFileSync('./index.html', 'utf-8')
const renderer = require('vue-server-renderer').createBundleRenderer(bundleCode)
app.get('*', (req, res) => {
const context = { url: req.url }
renderer.renderToStream(context)
.on('error', err => {
// handle render stream error before piping to the transform
})
.pipe(new HTMLStream({ context, template }))
.pipe(res)
})
FAQs
Transform stream to simplify Vue SSR streaming
We found that vue-ssr-html-stream demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Security News
n8n led JavaScript Rising Stars 2025 by a wide margin, with workflow platforms seeing the largest growth across categories.

Security News
The U.S. government is rolling back software supply chain mandates, shifting from mandatory SBOMs and attestations to a risk-based approach.

Security News
crates.io adds a Security tab backed by RustSec advisories and narrows trusted publishing paths to reduce common CI publishing risks.