Skip to content

Latest commit

 

History

History
132 lines (97 loc) · 4.55 KB

creando-el-primer-componente-reutilizable-con-react.md

File metadata and controls

132 lines (97 loc) · 4.55 KB

🎉 4) Creando el primer componente reutilizable con React

Arquitectura orientada a componentes

Las aplicaciones construidas con react tienen una arquitectura orientada a componentes. Esto provee un nivel de abstracción mayor que colabora a que podamos tener muchos componentes reutilizables a lo largo de la aplicación, facilitando el desarrollo y el mantenimiento.

Primer componente reutilizable

Vamos a crear nuestro primer componente reutilizable, en este ejemplo haremos una card utilizada en la home de Mercado Libre.

promotion

Componentes del componente

A simple vista podemos ver que este componente contiene varios sub componentes: Imagen, categoría, título y botón.

Si pensamos cómo podríamos estructurar este componente podríamos tener algo así:

const HomeCard = (
    <Card>
        <Image src="https://cdn.mercadolibre.com/mercado-pago.png" />
        <Information>
            <Category description="POINT" />
            <Title description="ACEPTA TARJETAS" />
        </Information>
        <Button label="Ver más" />
    </Card>
);

Estos tags no son tags de HTML, sino que cada uno de ellos son un componente de nuestra propia aplicación.

Ya empezamos a entender cómo se estructuran las aplicaciones en react. Ahora necesitamos que nuestro componente pueda cargar la información dinámicamente, hasta ahora los datos están fijos por lo tanto no es un componente reutilizable.

Pasando props a nuestro componente

Conceptualmente todo componente react es una function que recibe propiedades y retorna react elements.

const HelloWord = (props) => {
    return <div>{props.text}</div>;
}

Babel transformará este código a:

var HelloWord = function HelloWord(props) {
    return React.createElement(
        "div",
        null,
        props.text
    );
}

Nuestro ejemplo

Sigamos con nuestro componente de ejemplo, pensemos que props podríamos pasarle para hacer que el componente sea reutilizable.

const HomeCard = (props) => (
    <Card>
        <Image src={props.image} />
        <Information>
            <Category description={props.category} />
            <Title description={props.description} />
        </Information>
        <Button label={props.buttonLabel} />
    </Card>
);

El componente ahora carga la información de manera dinámica, por lo tanto podemos utilizarlo desde varios lugares dentro de nuestra aplicación.

Para repasar sobre la importancia del uso de JSX veamos cómo sería escribir nuestro componente sin JSX.

var HomeCard = function HomeCard(props) {
    return React.createElement(
        Card,
        null,
        React.createElement(Image, { src: props.image }),
        React.createElement(
            Information,
            null,
            React.createElement(Category, { description: props.category }),
            React.createElement(Title, { description: props.description })
        ),
        React.createElement(Button, { label: props.buttonLabel })
    );
};

Utilizando nuestro componente

Ahora que hicimos reutilizable nuestro componente, hagamos un ejemplo sobre cómo utilizarlo.

import HomeCard from './components/HomeCard';

<div>
    <HomeCard
        image="https://cdn.mercadolibre.com/mercado-pago.png"
        category="POINT"
        description="ACEPTA TARJETAS"
        buttonLabel="Ver más"
    />
    <HomeCard
        image="https://cdn.mercadolibre.com/diseno-deco.png"
        category="DISEÑO Y DECO"
        description="ESPACIOS DE DISEÑO"
        buttonLabel="Ver más"
    />
</div>

Hermoso, nuestro componente ya es completamente reutilizable. Esto lo logramos gracias a las props de react.

Es importante tratar de dividir nuestra aplicación en componentes lo más pequeños posibles, esto ayuda a que escribamos menos código, tengamos aplicaciones robustas, con menos bugs, testeables y fáciles de mantener.

Práctico

Llevemos esto a la práctica:

{% embed data="{"url":"https://github.com/workshopsjsmvd/react/tree/master/practico\",\"type\":\"link\",\"title\":\"workshopsjsmvd/react\",\"description\":\"react - Workshop sobre React","icon":{"type":"icon","url":"https://github.com/fluidicon.png\",\"aspectRatio\":0},\"thumbnail\":{\"type\":\"thumbnail\",\"url\":\"https://avatars1.githubusercontent.com/u/38766393?s=400&v=4\",\"width\":240,\"height\":240,\"aspectRatio\":1}}" %}