تایپهای کاربردی
اطلاعات
این صفحه فقط چند تایپ کاربردی(utility types) را فهرست میکند که ممکن است برای استفاده از آنها نیاز به توضیح باشد. برای فهرست کامل تایپهای صادر شده، به کد منبع مراجعه کنید.
PropType<T>
برای یادداشت نویسی(annotate) یک پراپ با تایپهای پیشرفتهتر (advanced types) هنگام استفاده از اعلامیههای پراپهای رانتایم استفاده میشود.
مثال
tsimport type { PropType } from 'vue' interface Book { title: string author: string year: number } export default { props: { book: { // provide more specific type to `Object` type: Object as PropType<Book>, required: true } } }
همچنین ببینید Guide - Typing Component Props
MaybeRef<T>
نام مستعار برای T | Ref<T>
. مفید برای حاشیه نویسی آرگومانهای Composables.
- فقط در 3.3+ پشتیبانی میشود.
MaybeRefOrGetter<T>
نام مستعار برای T | Ref<T> | (() => T)
. مفید برای حاشیه نویسی آرگومانهای Composables.
- فقط در 3.3+ پشتیبانی میشود.
ExtractPropTypes<T>
تایپهای پراپ را از یک آبجکت آپشنهای پراپها رانتایم استخراج کنید. تایپهای استخراجشده رو به داخل هستند - یعنی پراپهای حلشده توسط کامپوننت دریافت شده. این بدان معناست که پایههای بولی و پایههای با مقادیر پیشفرض همیشه تعریف میشوند، حتی اگر مورد نیاز نباشند.
برای استخراج کردن پراپهای عمومی، بهعنوان مثال پراپهایی که والد مجاز به عبور از آن است، از ExtractPublicPropTypes
استفاده کنید.
مثال
tsconst propsOptions = { foo: String, bar: Boolean, baz: { type: Number, required: true }, qux: { type: Number, default: 1 } } as const type Props = ExtractPropTypes<typeof propsOptions> // { // foo?: string, // bar: boolean, // baz: number, // qux: number // }
ExtractPublicPropTypes<T>
تایپهای پراپ را از یک آبجکت آپشنهای پراپهای رانتایم را استخراج کنید. تایپهای استخراج شده در معرض عموم قرار دارند - یعنی پراپهایی که والد مجاز به عبور از آنها است.
مثال
tsconst propsOptions = { foo: String, bar: Boolean, baz: { type: Number, required: true }, qux: { type: Number, default: 1 } } as const type Props = ExtractPublicPropTypes<typeof propsOptions> // { // foo?: string, // bar?: boolean, // baz: number, // qux?: number // }
ComponentCustomProperties
برای افزایش تایپ نمونه کامپوننت جهت پشتیبانی از پراپرتیهای سراسری سفارشی استفاده میشود.
مثال
tsimport axios from 'axios' declare module 'vue' { interface ComponentCustomProperties { $http: typeof axios $translate: (key: string) => string } }
نکته
افزایشها باید در یک ماژول
.ts
یا.d.ts
قرار گیرند. برای جزئیات بیشتر به Type Augmentation Placement مراجعه کنید.همچنین ببینید Guide - Augmenting Global Properties
ComponentCustomOptions
برای افزایش تایپ آپشنهای کامپوننت جهت پشتیبانی از آپشنهای سفارشی استفاده میشود.
مثال
tsimport { Route } from 'vue-router' declare module 'vue' { interface ComponentCustomOptions { beforeRouteEnter?(to: any, from: any, next: () => void): void } }
نکته
افزایشها باید در یک ماژول
.ts
یا.d.ts
قرار گیرند. برای جزئیات بیشتر به Type Augmentation Placement مراجعه کنید.همچنین ببینید Guide - Augmenting Custom Options
ComponentCustomProps
برای افزایش پراپهای مجاز TSX به منظور استفاده از پراپهای اعلام نشده (non-declared) در عناصر TSX استفاده میشود.
مثال
tsdeclare module 'vue' { interface ComponentCustomProps { hello?: string } } export {}
tsx// now works even if hello is not a declared prop <MyComponent hello="world" />
نکته
افزایشها باید در یک ماژول
.ts
یا.d.ts
قرار گیرند. برای جزئیات بیشتر به Type Augmentation Placement مراجعه کنید.
CSSProperties
برای افزایش مقادیر مجاز در پراپرتیهای متصل کردن استایل استفاده میشود.
مثال
اجازه دادن به هر پراپرتی سفارشی CSS
tsdeclare module 'vue' { interface CSSProperties { [key: `--${string}`]: string } }
tsx<div style={ { '--bg-color': 'blue' } }>
html<div :style="{ '--bg-color': 'blue' }"></div>
نکته
افزایشها باید در یک ماژول .ts
یا .d.ts
قرار گیرند. برای جزئیات بیشتر به Type Augmentation Placement مراجعه کنید.
همچنین ببینید
تگهای <style>
یک SFC از لینک کردن مقادیر CSS به استیتهای پویا کامپوننت با استفاده از تابع v-bind
CSS پشتیبانی میکنند. این امکان را برای پراپرتیهای سفارشی بدون افزایش تایپ فراهم می کند.