Passer au contenu
Sur cette page

Options : Composition

provide

Fournit des valeurs qui peuvent être injectées par les composants descendants.

  • Type :

    ts
    interface ComponentOptions {
      provide?: object | ((this: ComponentPublicInstance) => object)
    }
  • Détails

    provide et inject sont utilisées ensemble pour permettre à un composant ancêtre de servir d'injecteur de dépendances pour tous ses descendants, peu importe la profondeur de la hiérarchie des composants, tant qu'ils sont de la même lignée.

    L'option provide doit être soit un objet, soit une fonction qui renvoie un objet. Cet objet contient les propriétés qui sont disponibles pour l'injection dans ses descendants. Vous pouvez utiliser des symboles comme clés dans cet objet.

  • Exemple

    Utilisation basique :

    js
    const s = Symbol()
    
    export default {
      provide: {
        foo: 'foo',
        [s]: 'bar'
      }
    }

    Utilisation d'une fonction pour fournir un état par composant :

    js
    export default {
      data() {
        return {
          msg: 'foo'
        }
      }
      provide() {
        return {
          msg: this.msg
        }
      }
    }

    Notez que dans l'exemple ci-dessus, le msg fourni ne sera PAS réactif. Consultez travailler avec la réactivité pour plus de détails.

  • Voir aussi Provide / Inject

inject

Déclare les propriétés à injecter dans le composant actuel en les localisant à partir des fournisseurs ancêtres.

  • Type :

    ts
    interface ComponentOptions {
      inject?: ArrayInjectOptions | ObjectInjectOptions
    }
    
    type ArrayInjectOptions = string[]
    
    type ObjectInjectOptions = {
      [key: string | symbol]:
        | string
        | symbol
        | { from?: string | symbol; default?: any }
    }
  • Détails

    L'option inject doit être soit :

    • Un tableau de chaînes de caractères, ou
    • Un objet où les clés sont le nom de la liaison locale et la valeur est soit :
      • La clé (chaîne de caractères ou symbole) à rechercher dans les injections disponibles, ou bien
      • Un objet où :
        • La propriété from est la clé (chaîne de caractères ou symbole) à rechercher dans les injections disponibles, et
        • La propriété default est utilisée comme valeur de secours. Comme pour les valeurs par défaut des props, une fonction factory est nécessaire pour les types objets afin d'éviter le partage de valeurs entre plusieurs instances de composants.

    Une propriété injectée sera undefined si aucune propriété correspondante ou valeur par défaut n'a été fournie.

    Notez que les liaisons injectées ne sont PAS réactives. Ceci est intentionnel. Cependant, si la valeur injectée est un objet réactif, les propriétés de cet objet restent réactives. Consultez travailler avec la réactivité pour plus de détails.

  • Exemple

    Utilisation basique :

    js
    export default {
      inject: ['foo'],
      created() {
        console.log(this.foo)
      }
    }

    En utilisant une valeur injectée comme valeur par défaut pour une prop :

    js
    const Child = {
      inject: ['foo'],
      props: {
        bar: {
          default() {
            return this.foo
          }
        }
      }
    }

    En utilisant une valeur injectée comme entrée de données :

    js
    const Child = {
      inject: ['foo'],
      data() {
        return {
          bar: this.foo
        }
      }
    }

    Les injections peuvent être optionnelles avec une valeur par défaut :

    js
    const Child = {
      inject: {
        foo: { default: 'foo' }
      }
    }

    Si l'injection doit se faire à partir d'une propriété portant un nom différent, utilisez from pour désigner la propriété source :

    js
    const Child = {
      inject: {
        foo: {
          from: 'bar',
          default: 'foo'
        }
      }
    }

    Comme pour les valeurs par défaut des props, vous devez utiliser une fonction factory pour les valeurs non primitives :

    js
    const Child = {
      inject: {
        foo: {
          from: 'bar',
          default: () => [1, 2, 3]
        }
      }
    }
  • Voir aussi Provide / Inject

mixins

Un tableau d'objets d'options à introduire dans le composant actuel.

  • Type :

    ts
    interface ComponentOptions {
      mixins?: ComponentOptions[]
    }
  • Détails

    L'option mixins accepte un tableau d'objets mixins. Ces objets mixins peuvent contenir des options d'instance comme des objets d'instance normaux, et ils seront fusionnés avec les options éventuelles en utilisant la logique de fusion des options. Par exemple, si votre mixin contient un hook created et que le composant lui-même en possède un, les deux fonctions seront appelées.

    Les hooks des mixins sont appelés dans l'ordre où ils sont fournis, et sont appelés avant les propres hooks du composant.

    N'est plus recommandé

    Avec Vue 2, les mixins étaient le principal mécanisme pour créer des morceaux réutilisables des logiques de composants. Bien que les mixins continuent d'être pris en charge avec Vue 3, la Composition API est désormais l'approche privilégiée pour la réutilisation du code entre les composants.

  • Exemple

    js
    const mixin = {
      created() {
        console.log(1)
      }
    }
    
    createApp({
      created() {
        console.log(2)
      },
      mixins: [mixin]
    })
    
    // => 1
    // => 2

extends

Un composant de la "classe de base" à partir duquel on peut étendre un composant.

  • Type :

    ts
    interface ComponentOptions {
      extends?: ComponentOptions
    }
  • Détails

    Permet à un composant d'en étendre un autre, en héritant de ses options de composant.

    Du point de vue de l'implémentation, extends est presque identique à mixins. Le composant spécifié par extends sera traité comme s'il était le premier mixin.

    Cependant, extends et mixins expriment des intentions différentes. L'option mixins est principalement utilisée pour composer des morceaux de fonctionnalité, alors que extends est principalement concerné par l'héritage.

    Comme avec mixins, toutes les options (excepté pour setup()) seront fusionnées en utilisant la stratégie de fusion appropriée.

  • Exemple

    js
    const CompA = { ... }
    
    const CompB = {
      extends: CompA,
      ...
    }

    Not Recommended for Composition API

    extends is designed for Options API and does not handle the merging of the setup() hook.

    In Composition API, the preferred mental model for logic reuse is "compose" over "inheritance". If you have logic from a component that needs to be reused in another one, consider extracting the relevant logic into a Composable.

    If you still intend to "extend" a component using Composition API, you can call the base component's setup() in the extending component's setup():

    js
    import Base from './Base.js'
    export default {
      extends: Base,
      setup(props, ctx) {
        return {
          ...Base.setup(props, ctx),
          // local bindings
        }
      }
    }
Options : Compositiona chargé