179 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			179 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
# @vue/server-renderer
 | 
						|
 | 
						|
**Note: as of 3.2.13+, this package is included as a dependency of the main `vue` package and can be accessed as `vue/server-renderer`. This means you no longer need to explicitly install this package and ensure its version match that of `vue`'s. Just use the `vue/server-renderer` deep import instead.**
 | 
						|
 | 
						|
## Basic API
 | 
						|
 | 
						|
### `renderToString`
 | 
						|
 | 
						|
**Signature**
 | 
						|
 | 
						|
```ts
 | 
						|
function renderToString(
 | 
						|
  input: App | VNode,
 | 
						|
  context?: SSRContext,
 | 
						|
): Promise<string>
 | 
						|
```
 | 
						|
 | 
						|
**Usage**
 | 
						|
 | 
						|
```js
 | 
						|
const { createSSRApp } = require('vue')
 | 
						|
const { renderToString } = require('@vue/server-renderer')
 | 
						|
 | 
						|
const app = createSSRApp({
 | 
						|
  data: () => ({ msg: 'hello' }),
 | 
						|
  template: `<div>{{ msg }}</div>`,
 | 
						|
})
 | 
						|
 | 
						|
;(async () => {
 | 
						|
  const html = await renderToString(app)
 | 
						|
  console.log(html)
 | 
						|
})()
 | 
						|
```
 | 
						|
 | 
						|
### Handling Teleports
 | 
						|
 | 
						|
If the rendered app contains teleports, the teleported content will not be part of the rendered string. Instead, they are exposed under the `teleports` property of the ssr context object:
 | 
						|
 | 
						|
```js
 | 
						|
const ctx = {}
 | 
						|
const html = await renderToString(app, ctx)
 | 
						|
 | 
						|
console.log(ctx.teleports) // { '#teleported': 'teleported content' }
 | 
						|
```
 | 
						|
 | 
						|
## Streaming API
 | 
						|
 | 
						|
### `renderToNodeStream`
 | 
						|
 | 
						|
Renders input as a [Node.js Readable stream](https://nodejs.org/api/stream.html#stream_class_stream_readable).
 | 
						|
 | 
						|
**Signature**
 | 
						|
 | 
						|
```ts
 | 
						|
function renderToNodeStream(input: App | VNode, context?: SSRContext): Readable
 | 
						|
```
 | 
						|
 | 
						|
**Usage**
 | 
						|
 | 
						|
```js
 | 
						|
// inside a Node.js http handler
 | 
						|
renderToNodeStream(app).pipe(res)
 | 
						|
```
 | 
						|
 | 
						|
**Note:** This method is not supported in the ESM build of `@vue/server-renderer`, which is decoupled from Node.js environments. Use `pipeToNodeWritable` instead.
 | 
						|
 | 
						|
### `pipeToNodeWritable`
 | 
						|
 | 
						|
Render and pipe to an existing [Node.js Writable stream](https://nodejs.org/api/stream.html#stream_writable_streams) instance.
 | 
						|
 | 
						|
**Signature**
 | 
						|
 | 
						|
```ts
 | 
						|
function pipeToNodeWritable(
 | 
						|
  input: App | VNode,
 | 
						|
  context: SSRContext = {},
 | 
						|
  writable: Writable,
 | 
						|
): void
 | 
						|
```
 | 
						|
 | 
						|
**Usage**
 | 
						|
 | 
						|
```js
 | 
						|
// inside a Node.js http handler
 | 
						|
pipeToNodeWritable(app, {}, res)
 | 
						|
```
 | 
						|
 | 
						|
### `renderToWebStream`
 | 
						|
 | 
						|
Renders input as a [Web ReadableStream](https://developer.mozilla.org/en-US/docs/Web/API/Streams_API).
 | 
						|
 | 
						|
**Signature**
 | 
						|
 | 
						|
```ts
 | 
						|
function renderToWebStream(
 | 
						|
  input: App | VNode,
 | 
						|
  context?: SSRContext,
 | 
						|
): ReadableStream
 | 
						|
```
 | 
						|
 | 
						|
**Usage**
 | 
						|
 | 
						|
```js
 | 
						|
// inside an environment with ReadableStream support
 | 
						|
return new Response(renderToWebStream(app))
 | 
						|
```
 | 
						|
 | 
						|
**Note:** in environments that do not expose `ReadableStream` constructor in the global scope, `pipeToWebWritable` should be used instead.
 | 
						|
 | 
						|
### `pipeToWebWritable`
 | 
						|
 | 
						|
Render and pipe to an existing [Web WritableStream](https://developer.mozilla.org/en-US/docs/Web/API/WritableStream) instance.
 | 
						|
 | 
						|
**Signature**
 | 
						|
 | 
						|
```ts
 | 
						|
function pipeToWebWritable(
 | 
						|
  input: App | VNode,
 | 
						|
  context: SSRContext = {},
 | 
						|
  writable: WritableStream,
 | 
						|
): void
 | 
						|
```
 | 
						|
 | 
						|
**Usage**
 | 
						|
 | 
						|
This is typically used in combination with [`TransformStream`](https://developer.mozilla.org/en-US/docs/Web/API/TransformStream):
 | 
						|
 | 
						|
```js
 | 
						|
// TransformStream is available in environments such as CloudFlare workers.
 | 
						|
// in Node.js, TransformStream needs to be explicitly imported from 'stream/web'
 | 
						|
const { readable, writable } = new TransformStream()
 | 
						|
pipeToWebWritable(app, {}, writable)
 | 
						|
 | 
						|
return new Response(readable)
 | 
						|
```
 | 
						|
 | 
						|
### `renderToSimpleStream`
 | 
						|
 | 
						|
Renders input in streaming mode using a simple readable interface.
 | 
						|
 | 
						|
**Signature**
 | 
						|
 | 
						|
```ts
 | 
						|
function renderToSimpleStream(
 | 
						|
  input: App | VNode,
 | 
						|
  context: SSRContext,
 | 
						|
  options: SimpleReadable,
 | 
						|
): SimpleReadable
 | 
						|
 | 
						|
interface SimpleReadable {
 | 
						|
  push(content: string | null): void
 | 
						|
  destroy(err: any): void
 | 
						|
}
 | 
						|
```
 | 
						|
 | 
						|
**Usage**
 | 
						|
 | 
						|
```js
 | 
						|
let res = ''
 | 
						|
 | 
						|
renderToSimpleStream(
 | 
						|
  app,
 | 
						|
  {},
 | 
						|
  {
 | 
						|
    push(chunk) {
 | 
						|
      if (chunk === null) {
 | 
						|
        // done
 | 
						|
        console(`render complete: ${res}`)
 | 
						|
      } else {
 | 
						|
        res += chunk
 | 
						|
      }
 | 
						|
    },
 | 
						|
    destroy(err) {
 | 
						|
      // error encountered
 | 
						|
    },
 | 
						|
  },
 | 
						|
)
 | 
						|
```
 |