Composition API: Helpers
useAttrs()
Vrací objekt attrs
ze Setup Context, který obsahuje fallthrough atributy aktuální komponenty. Funkce je určena pro použití uvnitř <script setup>
, kde není setup context objekt dostupný.
Typ
tsfunction useAttrs(): Record<string, unknown>
useSlots()
Vrací objekt slots
ze Setup Context, který obsahuje sloty (slots) předané z komponenty rodiče ve formě spustitelných funkcí vracejících Virtuální DOM uzly. Funkce je určena pro použití uvnitř <script setup>
, kde není setup context objekt dostupný.
Při použití TypeScriptu je preferovaná varianta využít defineSlots()
.
Typ
tsfunction useSlots(): Record<string, (...args: any[]) => VNode[]>
useModel()
Toto je pomocná funkce, která uvnitř pohání defineModel()
. Při použití <script setup>
je preferovaná varianta využít defineModel()
.
Funkce useModel()
může být použita v non-SFC komponentách, např. uvnitř obyčejné setup()
funkce. Jako první parametr očekává props
objekt a jako druhý název modelu. Volitelný třetí parametr může být použit pro deklaraci vlastního getteru a setteru pro výsledný ref objekt modelu. Pamatujte, že na rozdíl od defineModel()
jste za deklaraci vlastností (props) a událostí (emits) zodpovědní vy.
Typ
tsfunction useModel( props: Record<string, any>, key: string, options?: DefineModelOptions ): ModelRef type DefineModelOptions<T = any> = { get?: (v: T) => any set?: (v: T) => any } type ModelRef<T, M extends PropertyKey = string, G = T, S = T> = Ref<G, S> & [ ModelRef<T, M, G, S>, Record<M, true | undefined> ]
Příklad
jsexport default { props: ['count'], emits: ['update:count'], setup(props) { const msg = useModel(props, 'count') msg.value = 1 } }
useTemplateRef()
Vrací shallowRef
, jehož hodnota bude synchronizovaná s elementem či komponentou uvnitř šablony s odpovídajícím ref
atributem.
Typ
tsfunction useTemplateRef<T>(key: string): Readonly<ShallowRef<T | null>>
Příklad
vue<script setup> import { useTemplateRef, onMounted } from 'vue' const inputRef = useTemplateRef('input') onMounted(() => { inputRef.value.focus() }) </script> <template> <input ref="input" /> </template>
Viz také:
useId()
useId()
je API, které je možné použití pro generování unikátních ID v aktuální aplikaci.
Typ
tsfunction useId(): string
Příklad
vue<script setup> import { useId } from 'vue' const id = useId() </script> <template> <form> <label :for="id">Jméno:</label> <input :id="id" type="text" /> </form> </template>
Podrobnosti
ID generované pomocí
useId()
je v rámci aplikace unikátní. Může být použito pro generování ID formulářových prvků a atributů pro přístupnost (accessibility). Více volání na stejné komponentě vygeneruje různá ID, různé instance stejné komponenty volajícíuseId()
budou mít také různá ID.Pro ID generovaná pomocí
useId()
je také garantována stabilita mezi vykreslením na serveru a na klientovi, takže mohou být použita v SSR aplikacích, aniž by docházelo k chybám hydratace (hydration mismatches).Pokud máte na jedné stránce více instancí Vue, můžete se vyhnout konfliktům mezi ID přidáním prefixu každé aplikaci pomocí
app.config.idPrefix
.