واجهة التخريج من جانب الخادم
()renderToString
مُصدر من
vue/server-renderer
النوع
tsfunction renderToString( input: App | VNode, context?: SSRContext ): Promise<string>
مثال
jsimport { createSSRApp } from 'vue' import { renderToString } from 'vue/server-renderer' const app = createSSRApp({ data: () => ({ msg: 'hello' }), template: `<div>{{ msg }}</div>` }) ;(async () => { const html = await renderToString(app) console.log(html) })()
نطاق التخريج من جانب الخادم
يمكنك تمرير كائن سياق اختياري ، والذي يمكن استخدامه لتسجيل بيانات إضافية أثناء التخريج ، على سبيل المثال الوصول إلى محتوى مكونات Teleport:
jsconst ctx = {} const html = await renderToString(app, ctx) console.log(ctx.teleports) // { '#teleported': 'teleported content' }
معظم الواجهات البرمجة الأخرى لـ SSR في هذه الصفحة تقبل أيضًا كائن سياق اختياريًا. يمكن الوصول إلى كائن السياق في شيفرة المكون عبر الدالة التركيبية المساعدة useSSRContext.
اطلع أيضاً دليل - التخريج من جانب الخادوم
()renderToNodeStream
يعرض المدخلات كـ Node.js Readable stream.
مُصدر من
vue/server-renderer
النوع
tsfunction renderToNodeStream( input: App | VNode, context?: SSRContext ): Readable
مثال
js// داخل معالج Node.js http renderToNodeStream(app).pipe(res)
ملاحظة
هذه الطريقة غير مدعومة في بناء ESM من
vue/server-renderer
، والذي يُفصل عن بيئات Node.js. استخدمpipeToNodeWritable
بدلاً من ذلك.
()pipeToNodeWritable
يعرض ويوجه إلى نسخة Node.js Writable stream ةموجود.
مُصدر من
vue/server-renderer
النوع
tsfunction pipeToNodeWritable( input: App | VNode, context: SSRContext = {}, writable: Writable ): void
مثال
js// داخل معالج Node.js http pipeToNodeWritable(app, {}, res)
()renderToWebStream
يعرض المدخلات كـ Web ReadableStream.
مُصدر من
vue/server-renderer
النوع
tsfunction renderToWebStream( input: App | VNode, context?: SSRContext ): ReadableStream
مثال
js// داخل بيئة مع دعم ReadableStream return new Response(renderToWebStream(app))
ملاحظة
في البيئات التي لا تكشف عن بناء
ReadableStream
في النطاق العام ، يجب استخدامpipeToWebWritable()
بدلاً من ذلك.
()pipeToWebWritable
يعرض ويوجه إلى نسخة Web WritableStream موجودة.
مُصدر من
vue/server-renderer
النوع
tsfunction pipeToWebWritable( input: App | VNode, context: SSRContext = {}, writable: WritableStream ): void
مثال
عادةً ما يستخدم هذا بجانب
TransformStream
:js// TransformStream متوفر في بيئات مثل CloudFlare workers. // في Node.js ، يجب استيراد TransformStream بشكل صريح من 'stream/web' const { readable, writable } = new TransformStream() pipeToWebWritable(app, {}, writable) return new Response(readable)
()renderToSimpleStream
يعرض المدخلات في وضع التدفق باستخدام واجهة قراءة بسيطة.
مُصدر من
vue/server-renderer
النوع
tsfunction renderToSimpleStream( input: App | VNode, context: SSRContext, options: SimpleReadable ): SimpleReadable interface SimpleReadable { push(content: string | null): void destroy(err: any): void }
مثال
jslet res = '' renderToSimpleStream( app, {}, { push(chunk) { if (chunk === null) { // تم console(`render complete: ${res}`) } else { res += chunk } }, destroy(err) { // واجه خطأ } } )
()useSSRContext
واجهة برمجية في وقت التشغيل التي تستخدم لاسترداد كائن السياق الذي يُمرر إلى renderToString()
أو الواجهات البرمجية الأخرى للتخريج من جانب الخادوم.
النوع
tsfunction useSSRContext<T = Record<string, any>>(): T | undefined
مثال
يمكن استخدام السياق المسترجع لإرفاق المعلومات المطلوبة لتخريج HTMLالـ النهائي (على سبيل المثال ، بيانات ترويسة الصفحة).
vue<script setup> import { useSSRContext } from 'vue' // تأكد من الاتصال به فقط أثناء التخريج من جانب الخادوم // https://vitejs.dev/guide/ssr.html#conditional-logic if (import.meta.env.SSR) { const ctx = useSSRContext() // ...قم بإرفاق الخاصيات بالسياق } </script>
data-allow-mismatch
A special attribute that can be used to suppress hydration mismatch warnings.
Example
html<div data-allow-mismatch="text">{{ data.toLocaleString() }}</div>
The value can limit the allowed mismatch to a specific type. Allowed values are:
text
children
(only allows mismatch for direct children)class
style
attribute
If no value is provided, all types of mismatches will be allowed.