Skip to content

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

    ts
    function 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

    ts
    function 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

    ts
    function 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

    js
    export 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.

useId()

useId() je API, které je možné použití pro generování unikátních ID v aktuální aplikaci.

  • Typ

    ts
    function 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.

Composition API: Helpers has loaded