Vue.js / Nuxt.js

Composition API

Setup function, ref, reactive, computed, watch, lifecycle hooks, composables, script setup

24 questions d'entretien·
Confirmé
1

Qu'est-ce que la Composition API dans Vue 3 ?

Réponse

La Composition API est une nouvelle façon d'organiser la logique des composants Vue en utilisant des fonctions de composition au lieu des options (data, methods, computed). Elle permet de regrouper la logique par fonctionnalité plutôt que par type d'option, facilitant la réutilisation du code via des composables. Elle offre aussi un meilleur support TypeScript et une meilleure organisation pour les composants complexes.

2

Quelle est la fonction principale utilisée dans la Composition API pour définir la logique d'un composant ?

Réponse

La fonction setup() est le point d'entrée de la Composition API. Elle s'exécute avant la création du composant, avant même created(). Elle reçoit les props et le contexte comme arguments et doit retourner un objet contenant les données et fonctions à exposer au template. C'est dans setup() qu'on utilise ref, reactive, computed, watch et les lifecycle hooks de la Composition API.

3

Quelle est la différence principale entre ref() et reactive() ?

Réponse

ref() crée une référence réactive pour une valeur primitive ou un objet, accessible via .value dans le script (mais auto-unwrapped dans les templates). reactive() crée un proxy réactif pour les objets et tableaux uniquement, sans nécessiter .value mais perd sa réactivité si déstructuré. ref() est plus polyvalent pour les primitives, reactive() est plus naturel pour les objets complexes mais nécessite toRef/toRefs pour la déstructuration.

4

Comment accéder à la valeur d'une ref dans la fonction setup() ?

5

Comment créer une propriété calculée (computed property) dans la Composition API ?

+21 questions d'entretien

Maîtrise Vue.js / Nuxt.js pour ton prochain entretien

Accède à toutes les questions, flashcards, tests techniques, exercices de code review et simulateurs d'entretien.

Commencer gratuitement