Vue 3 desde cero

Introducción a Componentes

La arquitectura de componentes es la base de Vue 3 y una de las principales ventajas a la hora de usar frameworks como este, ya que prácticamente todo puede convertirse en un componente para utilizarse (y reutilizarse) de forma modular


En esta última lección del Curso de Vue 3 daremos el primer paso para entender cómo funcionan los componentes, algo que veremos en profundidad más adelante en otros cursos.

La arquitectura de componentes es la base de Vue y una de las principales ventajas a la hora de usar frameworks como este, ya que prácticamente todo puede convertirse en un componente para utilizarse (y reutilizarse) de forma modular.

Para entender de qué estamos hablando vamos a mover a un componente toda la lógica y estructura que se encarga de mostrar el perfil de GitHub que hemos encontrado. Lo llamaremos AppProfile.js. Este es el aspecto que tiene.

JS
app.component("app-profile", {
    template:`
    <div class="result" v-if="result">
        <a v-if="isFavorite" href="#" class="result__toggle-favorite" @click="removeFavorite">Remove Favorite
            ⭐️</a>
        <a v-else href="#" class="result__toggle-favorite" @click="addFavorite">Add Favorite ⭐️</a>
        <h2 class="result__name">{{ result.name }}</h2>
        <img v-bind:src="result.avatar_url" :alt="result.name" class="result__avatar">
        <p class="result__bio">{{ result.bio }} <br>
            <a v-bind:href="result.blog" target="_blank" class="result__blog">{{ result.blog }}</a>
        </p>
    </div>
    `
})

    

Como ves dentro del componente existen referencias a propiedades y métodos que ya no existen dentro de su ámbito, ya que cada componente actúa como pieza aislada del resto del sistema. La forma en la que debemos satisfacer esas dependencias es a través de propiedades y eventos (una vez más, lo trataremos en profundidad más adelante).

Primero, debemos declarar y establecer esas propiedades y eventos en el propio componente.

JS
app.component("app-profile", {
    props: ['result', 'isFavorite'],
    methods: {
        addFavorite() {
            this.$emit('add-favorite')
        },
        removeFavorite() {
            this.$emit('remove-favorite')
        }
    },
    template: `...`
})

    

Luego, desde donde instanciamos el componente (index.html) pasamos de forma dinámica las propiedades y escuchamos los eventos.

HTML
<!-- Result -->
<Transition>
    <app-profile 
        v-if="result"
        :result="result"
        :is-favorite="isFavorite"
        @add-favorite="addFavorite"
        @remove-favorite="removeFavorite" />
</Transition>

    

De esta forma todo funciona exactamente igual que antes, pero podemos usar el componente en otras partes del proyecto, incluso en otros proyectos.

Enlaces

Juan Andrés Núñez
Juan Andrés Núñez
Ingeniero Frontend Senior. Especialista en Vue.js. Speaker. Docente profesional. Estoico.