Guide
Essentiel
- Installation
- Introduction
- Instance de Vue
- Syntaxe de template
- Propriétés calculées et observateurs
- Liaisons de classes et de styles
- Rendu conditionnel
- Rendu de liste
- Gestion des évènements
- Liaisons sur les champs de formulaire
- Composants
Composants en détail
- Création de composants
- Props
- Ãvènements personnalisés
- Slots
- Composants dynamiques et asynchrones
- Gérer les cas limites
Transitions & animation
- Transitions d'entrée, de sortie et de liste
- Transitions d'état
Réutilisabilité & composition
- Mixins
- Directives personnalisées
- Fonctions de rendu et JSX
- Plugins
- Filtres
Outils
- Composants monofichiers
- Testing
- Support de TypeScript
- Déploiement en production
Ãvolutions
- Routage
- Gestion de l'état
- Rendu côté serveur
- Security
Mécanismes
- Réactivité en détail
Migration
- Migration depuis Vue 1.x
- Migration depuis Vue Router 0.7.x
- Migration depuis Vuex 0.6.x à 1.0
Meta
- Comparaison avec les autres frameworks
- Rejoignez la communauté Vue.js !
- Rencontrer l'équipe
Youâre browsing the documentation for v2.x and earlier. For v3.x, click here.
Directives personnalisées
Introduction
En supplément de lâensemble de directives fournies par défaut (v-model
et v-show
), Vue vous permet également dâenregistrer vos propres directives. Notez quâavec Vue 2.0, les composants sont la forme principale de réutilisabilité et dâabstraction du code. Il y a cependant des cas où vous aurez juste besoin dâun accès de bas niveau aux éléments du DOM, et câest là que les directives personnalisées vous seraient utiles. Un exemple pourrait être la prise du focus sur un élément de champ, comme celui-ci :
Quand la page se charge, cet élément prend le focus (notez que autofocus
ne fonctionne pas sur Safari mobile). En fait, si vous nâavez cliqué sur rien du tout depuis votre arrivée sur la page, le champ ci-dessus devrait avoir le focus. à présent, jetons un Åil à la directive qui pourrait accomplir cela :
|
Si vous préférez enregistrer à la place la directive en local, les composants acceptent également lâoption directives
:
|
Puis dans un template, vous pouvez utiliser le nouvel attribut v-focus
sur nâimporte quel élément, comme celui-ci :
|
Fonctions de hook
Un objet de définition de directive peut fournir plusieurs fonctions de hook (toutes optionnelles) :
bind
: appelée une seule fois quand la directive est attachée à lâélément. Câest ici que vous pouvez effectuer les actions uniques dâinitialisation.inserted
: appelée quand lâélément lié a été inséré dans son nÅud parent (cela garantit uniquement sa présence dans le nÅud parent, mais pas nécessairement dans le document principal).update
: appelée après que le composant conteneur VNode a été mis à jour, mais possiblement avant que ses enfants aient été mis à jour. La valeur de la directive peut ou pas avoir changé, mais vous pouvez ignorer les mises à jour inutiles en comparant les valeurs actuelles et anciennes de la liaison (voir plus bas les arguments de hook).
Nous couvrirons VNodes plus en détail plus tard, quand nous discuterons des fonctions de rendu.
componentUpdated
: appelée après que le composant conteneur VNode et les VNode de ses enfants ont été mis à jour.unbind
: appelée uniquement une fois, quand la directive est déliée de lâélément.
Nous allons explorer les arguments passés à ces hooks (c.-à -d. el
, binding
, vnode
, et oldVnode
) dans la prochaine section.
Arguments des hooks dâune directive
Les hooks dâune directive ont accès à ces arguments :
el
: lâélément sur lequel la directive est liée. Cela peut être utilisé pour directement manipuler le DOM.binding
: un objet contenant les propriétés suivantes.name
: le nom de la directive, sans le préfixev-
.value
: la valeur passée à la directive. Par exemple dansv-my-directive="1 + 1"
, la valeur serait2
.oldValue
: la valeur précédente, seulement disponible dansupdate
etcomponentUpdated
. Elle est disponible, que la valeur ait changé ou non.expression
: lâexpression liée en tant que chaine de caractères. Par exemple dansv-my-directive="1 + 1"
, lâexpression serait"1 + 1"
.arg
: lâargument passé à la directive, sâil y en a une. Par exemple dansv-my-directive:foo
, lâargument serait"foo"
.modifiers
: un objet contenant les modificateurs, sâil y en a. Par exemple dansv-my-directive.foo.bar
, lâobjet des modificateurs serait{ foo: true, bar: true }
.
vnode
: le nÅud virtuel produit par le compilateur Vue. Voir lâAPI VNode pour tous les détails.oldVnode
: le nÅud virtuel précédent, seulement disponible dans les hooksupdate
etcomponentUpdated
.
à lâexception de el
, vous devez traiter ces arguments comme étant en lecture seule (« read-only ») et ne jamais les modifier. Si vous souhaitez partager des informations entre les hooks, il est recommandé de le faire à travers les attributs de données sur mesure de ses éléments (voir dataset).
Un exemple de directive personnalisée utilisant plusieurs de ces propriétés :
|
|
Arguments de directive dynamiques
Les arguments de directive peuvent être dynamiques. Par exemple, dans v-mydirective:[argument]="value"
, lâargument
peut-être mis à jour en se basant sur la propriété de donnée dans notre instance de composant ! Cela rend nos directives personnalisées flexibles à travers notre application.
Imaginons que vous vouliez créer une directive personnalisée qui vous permet dâattacher des éléments sur votre page en utilisant le positionnement fixe. Nous pourrions créer une directive personnalisée ou la valeur met à jour le positionnement vertical en nombre de pixel, comme ceci :
|
|
Cela va attacher lâélément à 200px depuis le haut de la page. Mais que ce passe t-il si nous somme dans un scénario ou nous avons besoin dâattacher lâélément sur la gauche à la place du haut ? Ici nous avons un argument dynamique qui peut être mis à jour pour chaque instance du composant de manière très pratique :
|
|
Résultat :
Nos directives personnalisées sont maintenant assez flexibles pour supporter différents cas dâutilisation.
Fonction abrégée
Dans de nombreux cas, vous pourriez vouloir le même comportement pour les hooks bind
et update
, sans avoir besoin des autres hooks. Par exemple :
|
Objets littéraux
Si votre directive a besoin de plusieurs valeurs, vous pouvez également passer un objet JavaScript. Souvenez-vous, une directive peut accepter nâimporte quelle expression JavaScript.
|
|