Vue و کامپوننتهای وب
کامپوننتهای وب یک اصطلاح کلی برای مجموعهای از APIهای بومی وب است که به توسعهدهندگان امکان میدهد تا المنتهای سفارشی قابل استفاده مجدد ایجاد کنند.
ما Vue و کامپوننتهای وب را فناوریهای مکمل یکدیگر در نظر میگیریم. Vue پشتیبانی عالی از استفاده و ایجاد المنتهای سفارشی ارائه میدهد. چه در حال یکپارچهسازی المنتهای سفارشی موجود در یک برنامه Vue باشید یا از Vue برای ساخت و توزیع المنتهای سفارشی استفاده کنید، در جایگاه خوبی قرار دارید.
استفاده از المنتهای سفارشی در Vue
Vue نمره 100% را در همه تستهای المنتهای سفارشی کسب کرده است. استفاده از المنتهای سفارشی داخل برنامه Vue تا حد زیادی مانند استفاده از المنتهای HTML بومی عمل میکند، با چند نکته که باید به آنها توجه داشت:
گذشتن از Component Resolution
به طور پیشفرض، Vue تلاش میکند قبل از اینکه یک تگ HTML غیربومی را به عنوان المنت سفارشی قبول کند به عنوان یک کامپوننت Vue ثبتشده در نظر بگیرد. این باعث میشود Vue در حین توسعه هشدار "failed to resolve component" را منتشر کند. برای اطلاع دادن به Vue که برخی المنت باید به عنوان المنتهای سفارشی در نظر گرفته شوند، میتوانیم از آپشن compilerOptions.isCustomElement
استفاده کنیم.
اگر از Vue با یک بیلد ستاپ استفاده میکنید، این آپشن باید از طریق تنظیمات بیلد ارسال شود زیرا یک آپشن زمان کامپایل است.
مثال از تنظیمات درون مرورگر
js
// اگر فقط از کامپایل درون مرورگر استفاده میکنید کار میکند
// اگر از ابزارهای بیلد استفاده میکنید، مثالهای پایین را ببینید
app.config.compilerOptions.isCustomElement = (tag) => tag.includes('-')
مثال از تنظیمات Vite
js
// vite.config.js
import vue from '@vitejs/plugin-vue'
export default {
plugins: [
vue({
template: {
compilerOptions: {
// همه تگهای دارای خطتیره را بهعنوان المنتهای سفارشی در نظر بگیر
isCustomElement: (tag) => tag.includes('-')
}
}
})
]
}
مثال از تنظیمات Vue CLI
js
// vue.config.js
module.exports = {
chainWebpack: (config) => {
config.module
.rule('vue')
.use('vue-loader')
.tap((options) => ({
...options,
compilerOptions: {
// treat any tag that starts with ion- as custom elements
isCustomElement: (tag) => tag.startsWith('ion-')
}
}))
}
}
Passing DOM Properties
از آنجایی که اتریبیوتها در DOM تنها میتوانند رشته باشند، برای انتقال دادههای پیچیده به المنتهای سفارشی به پراپرتیهای DOM نیاز داریم. هنگام تنظیم props روی یک المنت سفارشی، Vue 3 به طور خودکار با استفاده از عملگر in
وجود پراپرتی DOM را بررسی میکند و اگر کلید وجود داشته باشد، ترجیح میدهد مقدار را به عنوان پراپرتی DOM تنظیم کند. این بدان معناست که در اکثر موارد، اگر المنت سفارشی از شیوههای توصیه شده پیروی کند، نیاز نیست در مورد این موضوع فکر کنید.
با این حال، ممکن است موارد نادری وجود داشته باشد که دادهها باید به عنوان پراپرتی DOM انتقال یابند، اما المنت سفارشی به درستی پراپرتی را تعریف/انعکاس نمیدهد (باعث شکست بررسی in
میشود). در این مورد، میتوانید یک اتصال v-bind
را با استفاده از مُدیفایر .prop
مجبور به تنظیم به عنوان پراپرتی DOM کنید:
template
<my-element :user.prop="{ name: 'jack' }"></my-element>
<!-- معادل مختصر -->
<my-element .user="{ name: 'jack' }"></my-element>
ساخت المنتهای سفارشی با Vue
مزیت اصلی المنتهای سفارشی این است که میتوانند با هر فریمورکی یا حتی بدون فریمورک استفاده شوند. این آنها را برای توزیع کامپوننتها در مواردی که مصرفکننده نهایی ممکن است از یک استک فرانتاند مشابه استفاده نکند یا زمانی که میخواهید از جزئیات پیادهسازی کامپوننتها در برنامه نهایی محافظت کنید، ایدهآل میسازد.
defineCustomElement
Vue از طریق متد defineCustomElement
از ایجاد المنتهای سفارشی با استفاده از دقیقاً همان APIهای کامپوننت Vue پشتیبانی میکند. این متد همان آرگومانهای defineComponent
را میپذیرد، اما به جای آن یک سازنده المنت سفارشی را که از HTMLElement
مشتق شده را بازمیگرداند:
template
<my-vue-element></my-vue-element>
js
import { defineCustomElement } from 'vue'
const MyVueElement = defineCustomElement({
// در اینجاست Vue آپشنهای معمول کامپوننت
props: {},
emits: {},
template: `...`,
// defineCustomElement only: CSS to be injected into shadow root
styles: [`/* inlined css */`]
})
// المنت سفارشی را ثبت کنید
// `<my-vue-element>` پس از ثبت، همه تگهای
// روی صفحه ارتقا خواهند یافت
customElements.define('my-vue-element', MyVueElement)
// همچنین میتوانید از طریق کد المنت را مقداردهی اولیه کنید:
// (فقط پس از ثبت امکانپذیر است)
document.body.appendChild(
new MyVueElement({
// اولیه (اختیاری) props
})
)
چرخه حیات
یک المنت سفارشی Vue یک نمونه کامپوننت Vue داخلی را در shadow root اش مانت میکند زمانی که
connectedCallback
المنت برای اولین بار فراخوانی میشود.زمانی که
disconnectedCallback
المنت فراخوانی میشود، Vue پس از یک تیک microtask بررسی میکند که آیا المنت از سند جدا شده است.اگر المنت هنوز در سند باشد، این یک جابهجایی است و نمونه کامپوننت حفظ میشود.
اگر المنت از سند جدا شده باشد، این یک حذف است و نمونه کامپوننت آنمانت میشود.
Props
همهی prop های تعریفشده با آپشن
props
به عنوان پراپرتیهای روی المنت سفارشی تعریف میشوند. Vue به طور خودکار انعکاس بین اتریبیوتها/پراپرتیها را در جای مناسب انجام میدهد.اتریبیوتها همیشه به پراپرتیهای متناظر انعکاس داده میشوند.
پراپرتیها با تایپ داده اولیه (
string
یاboolean
یاnumber
) به عنوان اتریبیوتها انعکاس داده میشوند.
Vue همچنین خودکار props اعلامشده با تایپهای
Boolean
یاNumber
را زمانی که به عنوان اتریبیوتها (که همیشه رشته هستند) تنظیم میشوند، به نوع مورد نظر تبدیل میکند. به عنوان مثال، با توجه به اعلام props زیر:jsprops: { selected: Boolean, index: Number }
و استفاده از المنت سفارشی:
template<my-element selected index="1"></my-element>
در کامپوننت،
selected
بهtrue
(تایپ: Boolean) وindex
به1
(تایپ: Number) تبدیل خواهد شد.
رویدادها
رویدادهایی که از طریق this.$emit
یا emit
موجود در setup، ارسال میشوند، به عنوان CustomEvents بومی روی المنت سفارشی ارسال میشوند. آرگومانهای اضافی رویداد (payload) به عنوان یک آرایه روی آبجکت CustomEvent از پراپرتی detail
آن قابل دسترسی خواهند بود.
Slots
درون کامپوننت، اسلاتها میتوانند با استفاده از المنت <slot/>
مثل همیشه رندر شوند. با این حال هنگام استفاده، المنت حاصل فقط از سینتکس اسلات بومی پشتیبانی میکند:
اسلاتهای دارای اسکوپ پشتیبانی نمیشوند.
هنگام ارسال اسلاتهای نامگذاریشده، از خاصیت
slot
به جای دایرکتیوv-slot
استفاده کنید:template<my-element> <div slot="named">hello</div> </my-element>
Provide / Inject
API مربوط به Provide / Inject و معادل آن در Composition API در المنتهای سفارشی تعریفشده با Vue کار میکنند. با این حال، توجه داشته باشید که این فقط بین المنتهای سفارشی کار میکند. یعنی یک المنت سفارشی تعریفشده در Vue نمیتواند پراپرتیهای ارائهشده توسط یک کامپوننت Vue غیرسفارشی را تزریق کند.
App Level Config
می توانید نمونه برنامه یک کامپوننت سفارشی Vue را با استفاده از آپشن configureApp
پیکربندی کنید:
js
defineCustomElement(MyComponent, {
configureApp(app) {
app.config.errorHandler = (err) => {
/* ... */
}
}
})
SFC به عنوان المنت سفارشی
defineCustomElement
همچنین با Vue Single-File Components (SFCs) کار میکند. با این حال، با تنظیم پیشفرض ابزار، <style>
داخل SFCها در حین بیلد پروداکشن استخراج و با هم به یک فایل CSS ترکیب میشوند. هنگام استفاده از یک SFC به عنوان یک المنت سفارشی، اغلب مطلوب است که تگهای <style>
را به جای آن به shadow root المنت سفارشی تزریق کنیم.
ابزارهای رسمی SFC از import کردن SFCها در "حالت المنت سفارشی" پشتیبانی میکنند (نیازمند @vitejs/plugin-vue@^1.4.0
یا vue-loader@^16.5.0
). یک SFC بارگذاریشده در حالت المنت سفارشی، تگهای <style>
خود را به عنوان رشتههایی از CSS درونخطی تبدیل میکند و آنها را تحت آپشن styles
کامپوننت قرار میدهد. این مورد توسط defineCustomElement
برداشته میشود و هنگام مقداردهی اولیه المنت به shadow root آن تزریق میشود.
برای فعال کردن این حالت، کافی است نام فایل کامپوننت خود را با .ce.vue
تمام کنید:
js
import { defineCustomElement } from 'vue'
import Example from './Example.ce.vue'
console.log(Example.styles) // ["/* inlined css */"]
// convert into custom element constructor
const ExampleElement = defineCustomElement(Example)
// register
customElements.define('my-example', ExampleElement)
برای سفارشیسازی اینکه کدام فایلها باید در حالت المنت سفارشی import شوند (برای مثال، در نظر گرفتن همه SFCها به عنوان المنتهای سفارشی)، میتوانید آپشن customElement
را به پلاگینهای بیلد مربوطه ارسال کنید:
نکاتی برای کتابخانه المنتهای سفارشی Vue
هنگام ساخت المنتهای سفارشی با Vue، المنتهای به رانتایم Vue وابسته خواهند بود. یک هزینه پایه حدود ~16kb بسته به اینکه از چه ویژگیهایی در حال استفاده هستند، وجود دارد. این بدان معناست که استفاده از Vue ایدهآل نیست اگر در حال ارسال یک المنت سفارشی تکی هستید - شاید بخواهید از جاوااسکریپت خالص، petite-vue، یا فریمورکهایی که در اندازه رانتایم کوچک تخصص دارند، استفاده کنید. با این حال، اگر در حال ارسال تعداد زیادی از المنتهای سفارشی با منطق پیچیده هستید، اندازه پایه بیش از حد، توجیهپذیر است. زیرا Vue به هر کامپوننت اجازه میدهد با کد خیلی کمتری نوشته شود. هر چه المنتهای بیشتری را با هم ارسال کنید، مبادله بهتر است.
اگر المنتهای سفارشی در یک برنامهای که از Vue هم استفاده میکند مورد استفاده قرار بگیرند، میتوانید انتخاب کنید Vue را از باندل خارجی استفاده کنید تا المنتها از همان کپی Vue موجود در برنامه میزبان استفاده کنند.
توصیه میشود سازندههای المنتهای جدا از هم را export کنید تا به کاربرانتان انعطافپذیری بدهید آنها را در زمان نیاز import کنند و با نام تگ دلخواه ثبت نمایند. همچنین میتوانید یک تابع مقداردهی اولیه را export کنید تا خودکار همه المنتها را ثبت کند. مثالی از نقطه ورود یک کتابخانه المنتهای سفارشی Vue:
js
// elements.js
import { defineCustomElement } from 'vue'
import Foo from './MyFoo.ce.vue'
import Bar from './MyBar.ce.vue'
const MyFoo = defineCustomElement(Foo)
const MyBar = defineCustomElement(Bar)
// export individual elements
export { MyFoo, MyBar }
export function register() {
customElements.define('my-foo', MyFoo)
customElements.define('my-bar', MyBar)
}
مصرفکننده میتواند از المنتهای موجود در یک فایل Vue استفاده کند.
vue
<script setup>
import { register } from 'path/to/elements.js'
register()
</script>
<template>
<my-foo ...>
<my-bar ...></my-bar>
</my-foo>
</template>
یا در هر فریمورک دیگری مانند فریمورکی که از JSX استفاده میکند، و با نامهای دلخواه:
jsx
import { MyFoo, MyBar } from 'path/to/elements.js'
customElements.define('some-foo', MyFoo)
customElements.define('some-bar', MyBar)
export function MyComponent() {
return <>
<some-foo ...>
<some-bar ...></some-bar>
</some-foo>
</>
}
کامپوننتهای وب مبتنی بر Vue و TypeScript
هنگام نوشتن تمپلیت تک صفحهای vue، ممکن است بخواهید کامپوننتهای Vue خود از جمله آنهایی که به عنوان المنتهای سفارشی تعریف شدهاند را type check کنید.
المنتهای سفارشی به طور سراسری در مرورگر با استفاده از APIهای بومی ثبت میشوند، بنابراین به طور پیشفرض هنگام استفاده در تمپلیتهای Vue ما type inference نخواهیم داشت. برای فراهم کردن پشتیبانی از تایپ برای کامپوننتهای Vue ما، که به عنوان المنتهای سفارشی ثبت شدهاند، میتوانیم تایپهای سراسری کامپوننت را با استفاده از GlobalComponents interface در تمپلیتهای Vue و یا در JSX ثبت کنیم.
در اینجا نحوه تعریف تایپ یک المنت سفارشی ساخته شده با Vue آمده است:
typescript
import { defineCustomElement } from 'vue'
// Import the Vue component.
import SomeComponent from './src/components/SomeComponent.ce.vue'
// Turn the Vue component into a Custom Element class.
export const SomeElement = defineCustomElement(SomeComponent)
// Remember to register the element class with the browser.
customElements.define('some-element', SomeElement)
// Add the new element type to Vue's GlobalComponents type.
declare module 'vue' {
interface GlobalComponents {
// Be sure to pass in the Vue component type here (SomeComponent, *not* SomeElement).
// Custom Elements require a hyphen in their name, so use the hyphenated element name here.
'some-element': typeof SomeComponent
}
}
کامپوننتهای وب غیر Vue و TypeScript
در اینجا روش پیشنهادی برای فعال کردن بررسی تایپ (Type Checking) در تمپلیتهای SFC برای المنتهای سفارشی که با Vue ساخته نشدهاند، ارائه شده است.
نکته
این روش یکی از راههای ممکن برای انجام آن است، اما ممکن است بسته به فریمورکی که برای ساخت المنتهای سفارشی استفاده میشود، متفاوت باشد.
فرض کنید یک المنت سفارشی داریم که دارای برخی ویژگیهای جاوا اسکریپتی (JS Properties) و رویدادهای تعریف شده است و در یک کتابخانه به نام some-lib
ارائه میشود:
ts
// file: some-lib/src/SomeElement.ts
// Define a class with typed JS properties.
export class SomeElement extends HTMLElement {
foo: number = 123
bar: string = 'blah'
lorem: boolean = false
// This method should not be exposed to template types.
someMethod() {
/* ... */
}
// ... implementation details omitted ...
// ... assume the element dispatches events named "apple-fell" ...
}
customElements.define('some-element', SomeElement)
// This is a list of properties of SomeElement that will be selected for type
// checking in framework templates (f.e. Vue SFC templates). Any other
// properties will not be exposed.
export type SomeElementAttributes = 'foo' | 'bar'
// Define the event types that SomeElement dispatches.
export type SomeElementEvents = {
'apple-fell': AppleFellEvent
}
export class AppleFellEvent extends Event {
/* ... details omitted ... */
}
جزئیات پیادهسازی حذف شدهاند،اما بخش مهم این است که ما تعریفهای تایپ برای دو مورد داریم: انواع ویژگیها (Prop Types) و انواع رویدادها (Event Types).
بیایید یک کمکی برای ثبت آسان تعریفهای تایپ المنتهای سفارشی در Vue ایجاد کنیم:
ts
// file: some-lib/src/DefineCustomElement.ts
// We can re-use this type helper per each element we need to define.
type DefineCustomElement<
ElementType extends HTMLElement,
Events extends EventMap = {},
SelectedAttributes extends keyof ElementType = keyof ElementType
> = new () => ElementType & {
// Use $props to define the properties exposed to template type checking. Vue
// specifically reads prop definitions from the `$props` type. Note that we
// combine the element's props with the global HTML props and Vue's special
// props.
/** @deprecated Do not use the $props property on a Custom Element ref, this is for template prop types only. */
$props: HTMLAttributes &
Partial<Pick<ElementType, SelectedAttributes>> &
PublicProps
// Use $emit to specifically define event types. Vue specifically reads event
// types from the `$emit` type. Note that `$emit` expects a particular format
// that we map `Events` to.
/** @deprecated Do not use the $emit property on a Custom Element ref, this is for template prop types only. */
$emit: VueEmit<Events>
}
type EventMap = {
[event: string]: Event
}
// This maps an EventMap to the format that Vue's $emit type expects.
type VueEmit<T extends EventMap> = EmitFn<{
[K in keyof T]: (event: T[K]) => void
}>
نکته
ما پراپرتیهای $props
و $emit
را بهعنوان منسوخ شده علامتگذاری کردهایم تا زمانی که به یک المنت سفارشی ارجاع (ref
) میگیریم، از این پراپرتیهای استفاده نکنیم. این پراپرتیهای فقط برای بررسی تایپ در کد مورد استفاده قرار میگیرند و در واقع روی نمونههای واقعی المنت سفارشی وجود ندارند.
با استفاده از این کمکی تایپ (type helper)، اکنون میتوانیم ویژگیهای جاوا اسکریپتی (JS properties) که باید برای بررسی تایپ در تمپلیتهای Vue نمایش داده شوند را انتخاب کنیم:
ts
// file: some-lib/src/SomeElement.vue.ts
import {
SomeElement,
SomeElementAttributes,
SomeElementEvents
} from './SomeElement.js'
import type { Component } from 'vue'
import type { DefineCustomElement } from './DefineCustomElement'
// Add the new element type to Vue's GlobalComponents type.
declare module 'vue' {
interface GlobalComponents {
'some-element': DefineCustomElement<
SomeElement,
SomeElementAttributes,
SomeElementEvents
>
}
}
فرض کنید که some-lib
فایلهای TypeScript خود را در پوشه dist/
کامپایل میکند. سپس یک کاربر از some-lib
میتواند SomeElement
را ایمپورت کرده و آن را در یک SFC ویو به این صورت استفاده کند:
vue
<script setup lang="ts">
// This will create and register the element with the browser.
import 'some-lib/dist/SomeElement.js'
// A user that is using TypeScript and Vue should additionally import the
// Vue-specific type definition (users of other frameworks may import other
// framework-specific type definitions).
import type {} from 'some-lib/dist/SomeElement.vue.js'
import { useTemplateRef, onMounted } from 'vue'
const el = useTemplateRef('el')
onMounted(() => {
console.log(
el.value!.foo,
el.value!.bar,
el.value!.lorem,
el.value!.someMethod()
)
// Do not use these props, they are `undefined` (IDE will show them crossed out):
el.$props
el.$emit
})
</script>
<template>
<!-- Now we can use the element, with type checking: -->
<some-element
ref="el"
:foo="456"
:blah="'hello'"
@apple-fell="
(event) => {
// The type of `event` is inferred here to be `AppleFellEvent`
}
"
></some-element>
</template>
اگر یک المنت تعریفهای تایپ را نداشته باشد، انواع ویژگیها و رویدادها را میتوان به صورت دستیتر تعریف کرد:
vue
<script setup lang="ts">
// Suppose that `some-lib` is plain JS without type definitions, and TypeScript
// cannot infer the types:
import { SomeElement } from 'some-lib'
// We'll use the same type helper as before.
import { DefineCustomElement } from './DefineCustomElement'
type SomeElementProps = { foo?: number; bar?: string }
type SomeElementEvents = { 'apple-fell': AppleFellEvent }
interface AppleFellEvent extends Event {
/* ... */
}
// Add the new element type to Vue's GlobalComponents type.
declare module 'vue' {
interface GlobalComponents {
'some-element': DefineCustomElement<
SomeElementProps,
SomeElementEvents
>
}
}
// ... same as before, use a reference to the element ...
</script>
<template>
<!-- ... same as before, use the element in the template ... -->
</template>
نویسندگان المنتهای سفارشی نباید به طور خودکار تعاریف تایپ المنتهای سفارشی مختص فریمورکها را از کتابخانههای خود اکسپورت کنند. به عنوان مثال، نباید این تعاریف را از یک فایل index.ts
که سایر بخشهای کتابخانه را نیز اکسپورت میکند، اکسپورت کنند؛ زیرا در غیر این صورت، کاربران با ارورهای غیرمنتظرهای در مورد گسترش ماژول (module augmentation) مواجه خواهند شد. کاربران باید فایل تعریف تایپ مختص فریمورکی را که نیاز دارند ایمپورت کنند.
کامپوننتهای Web در مقابل کامپوننتهای Vue
برخی توسعهدهندگان باور دارند که باید از مدلهای کامپوننت مخصوص به فریمورک اجتناب شود و استفاده انحصاری از المنتهای سفارشی، در بروزرسانیهای آینده برنامه را "پایدار" میکند. در اینجا تلاش میکنیم توضیح دهیم که چرا فکر میکنیم که این نگرش بیش از حد سادهگرا به مسئله است.
بدون شک، یک سطح مشخص از همپوشانی ویژگی بین المنتهای سفارشی و کامپوننتهای Vue وجود دارد: هر دو به ما این امکان را میدهند که کامپوننتهای قابل استفاده با انتقال داده، ایجاد رویداد و مدیریت چرخه حیات تعریف کنیم. با این حال، APIهای کامپوننتهای Web به نسبت سطح پایین و ابتدایی هستند. برای ساخت یک برنامه واقعی، ما به چندین قابلیت اضافی نیاز داریم که پلتفرم آنها را پوشش نمیدهد:
یک سیستم تمپلیتنویسی اعلامی و کارآمد؛
یک سیستم reactive state management که استخراج و استفاده از منطق مشترک بین کامپوننتها را تسهیل میکند؛
روش کارآمد برای رندر کردن کامپوننتها در سرور و قرار دادن آنها در مرورگر (SSR)، که برای بهینهسازی SEO و متریکهای Web Vitals مانند LCP اهمیت دارد. رندر المنتهای سفارشی SSR معمولاً شامل شبیهسازی DOM در Node.js و سپس سریالیسازی DOM متغیر میشود، در حالی که SSR در Vue هر زمان که امکان دارد به رشته های پیوسته کامپایل می شود، که به مراتب کارآمدتر است.
مدل کامپوننت Vue با توجه به این نیازها به عنوان یک سیستم منسجم طراحی شده است.
با یک تیم مهندسی ماهر، احتمالاً میتوانید معادل آن را بر روی المنتهای سفارشی اصلی بسازید - اما این همچنین به معنای بهعهدهگیری از بار نگهداری بلندمدت یک فریمورک داخلی است، در حالی که از مزایای جامعه و اکوسیستم یک فریمورک بالغ مانند Vue خارج میشوید.
همچنین فریمورکهایی وجود دارند که با استفاده از المنتهای سفارشی به عنوان پایه مدل کامپوننت خود ساخته شدهاند، اما همگی ناگزیراً باید به راهحلهای اختصاصی خود برای مشکلات فوق اشاره کنند. استفاده از این فریمورکها به معنای پذیرفتن تصمیمات فنی آنها درباره چگونگی حل این مشکلات است - که علیرغم تبلیغات ممکن است به صورت خودکار شما را از مشکلات احتمالی آینده محافظت نکند.
همچنین برخی حوزهها هستند که ما محدودیتهای المنتهای سفارشی را پیدا میکنیم:
ارزیابی فوری اسلات مانع از ترکیب کامپوننت میشود. اسلاتهای دارای اسکوپ Vue یک مکانیسم قدرتمند برای ترکیب کامپوننتها هست که به دلیل ماهیت فوری اسلاتهای اصلی، توسط المنتهای سفارشی پشتیبانی نمیشوند. اسلاتهای فوری همچنین به این معناست که کامپوننت دریافتکننده نمیتواند زمان یا اینکه آیا یک قطعه از محتوای اسلات را ارائه کند یا خیر، کنترل کند.
ارسال المنتهای سفارشی با CSS محدود به اسکوپ shadow DOM امروزه نیازمند قرار دادن CSS درون JavaScript است تا بتوانند در زمان اجرا به shadow root ها تزریق شوند. این نیز به معنای بروزرسانیهایی است که در این زمینه در حال انجام است - اما تا به حال به صورت یکپارچه پشتیبانی نشدهاند و هنوز نگرانیهای کارآیی پروداکشن / SSR باید برطرف شوند. در همین حال، Vue SFC مکانیزم های اسکوپینگ CSS را فراهم میکنند که از استخراج استایلها به فایلهای CSS ساده پشتیبانی میکنند.
Vue همیشه با آخرین استانداردهای پلتفرم وب همگام خواهد ماند، و اگر پلتفرم چیزی ارائه کند که کار ما را آسانتر کند، ما با خوشحالی از آن استفاده خواهیم کرد. با این حال، هدف ما ارائه راهکارهایی است که به خوبی کار کنند. این به این معناست که ما باید با یک دید انتقادی و توجه به ویژگیهای جدید پلتفرم، آنها را یکپارچه کنیم - و این به معنای پر کردن شکافها در جایی است که استانداردها هنوز بهطور کامل آنها را پوشش ندادهاند تا زمانی که این موضوع وجود دارد.