DEV Community

Software Engineer
Software Engineer

Posted on

React & Redux

React y Redux son dos herramientas de código abierto que se han convertido en una combinación popular para el desarrollo de aplicaciones web. React es una biblioteca de JavaScript que se utiliza para construir interfaces de usuario, mientras que Redux es un contenedor de estado que se utiliza para administrar el estado de la aplicación en una aplicación React.

React es una herramienta potente para construir interfaces de usuario escalables y de alto rendimiento. Su enfoque de "unidireccional" significa que los datos fluyen en una sola dirección, lo que facilita el mantenimiento y la depuración de grandes aplicaciones. Sin embargo, a medida que una aplicación crece en complejidad, el manejo del estado puede volverse complicado.

Aquí es donde entra Redux. Redux es un contenedor de estado global que se utiliza para almacenar el estado de la aplicación. Redux se basa en el patrón de diseño Flux, que se enfoca en el manejo del estado de una aplicación. La ventaja de Redux es que permite mantener un estado coherente y predecible en toda la aplicación, lo que facilita la comprensión y el mantenimiento del código.

La forma en que funciona Redux es que toda la información de estado se almacena en un solo "store". Cada vez que un componente necesita acceder al estado, lo hace a través de un "selector" que extrae los datos del store. Cuando se actualiza el estado, se envía una "acción" que describe la actualización al store, que actualiza el estado y notifica a todos los componentes que necesitan saber.

Al usar React y Redux juntos, se crea una aplicación escalable y fácil de mantener. La combinación de React y Redux facilita la actualización del estado de la aplicación y la propagación de esos cambios a través de la interfaz de usuario. Además, la estructura unidireccional de React complementa perfectamente el patrón unidireccional de Redux.

En resumen, React y Redux son dos herramientas de código abierto que se complementan entre sí para crear aplicaciones web escalables y fáciles de mantener. React se enfoca en la construcción de interfaces de usuario, mientras que Redux se enfoca en el manejo del estado de la aplicación. Al utilizar ambos juntos, se crea una aplicación coherente y predecible que es fácil de mantener y actualizar.

Ejemplo sencillo de cómo implementar Redux en un proyecto ReactJS

Supongamos que queremos crear una aplicación de contador. La idea es que al hacer clic en un botón "Aumentar", el número en pantalla aumentará en uno. Primero, creamos nuestro store en Redux:

import { createStore } from 'redux';

const initialState = { count: 0 };

function counterReducer(state = initialState, action) {
  switch (action.type) {
    case 'INCREMENT':
      return { count: state.count + 1 };
    default:
      return state;
  }
}

const store = createStore(counterReducer);

Enter fullscreen mode Exit fullscreen mode

Aquí, definimos un estado inicial de { count: 0 } y un reductor counterReducer que manejará las acciones. La única acción que manejará nuestro reductor es la de 'INCREMENT', que aumentará el valor de count en uno.

Luego, creamos un componente en React que se suscribe al store y renderiza el estado:

import React from 'react';
import { connect } from 'react-redux';

function Counter(props) {
  return (
    <div>
      <h1>Count: {props.count}</h1>
      <button onClick={props.increment}>Increase</button>
    </div>
  );
}

function mapStateToProps(state) {
  return { count: state.count };
}

function mapDispatchToProps(dispatch) {
  return { increment: () => dispatch({ type: 'INCREMENT' }) };
}

export default connect(mapStateToProps, mapDispatchToProps)(Counter);
Enter fullscreen mode Exit fullscreen mode

Aquí, usamos la función connect de React Redux para suscribir nuestro componente al store. La función mapStateToProps toma el estado del store y lo mapea a las props del componente, mientras que mapDispatchToProps mapea las acciones a los props del componente. En este caso, mapeamos la acción 'INCREMENT' al botón de aumento.

Finalmente, podemos usar nuestro componente en cualquier lugar de nuestra aplicación:

import React from 'react';
import ReactDOM from 'react-dom';
import { Provider } from 'react-redux';
import Counter from './Counter';
import store from './store';

ReactDOM.render(
  <Provider store={store}>
    <Counter />
  </Provider>,
  document.getElementById('root')
);
Enter fullscreen mode Exit fullscreen mode

Top comments (0)