Sabes cuándo un proyecto necesita HTML y CSS, porque son todos. Cuándo busca JavaScript es bastante claro: cuando necesita interactividad o alguna funcionalidad que solo JavaScript puede proporcionar. Solía ser bastante claro cuando buscábamos bibliotecas. Recurrimos a jQuery para ayudarnos a simplificar el trabajo con DOM, Ajax y manejar problemas entre navegadores con JavaScript. Usamos el guión bajo para brindarnos funciones auxiliares que JavaScript por sí solo no tenía.
A medida que la necesidad de estas bibliotecas se desvanece y vemos un aumento masivo de nuevos marcos, diría que no está tan claro cuando alcanzarlos. ¿En qué punto necesitamos React?
Solo voy a usar React como marcador de posición aquí para cosas un poco grandes del marco de JavaScript. Vue, Ember, Svelte… lo que sea. Entiendo que no son todos iguales, pero cuándo alcanzarlos me parece igualmente nebuloso.
Aquí está mi opinión.
✅ Porque hay mucho estado.
Incluso “estado” es una palabra un poco nebulosa. Imagina cosas como esta:
- Qué elemento de navegación está activo
- Si un botón está deshabilitado o no
- El valor de una entrada
- Qué secciones de acordeón se expanden
- Cuando un área se está cargando
- El usuario que está logueado y el equipo al que pertenece
- Si el elemento en el que está trabajando el usuario está publicado o es un borrador
Cosas del tipo “lógica de negocios” con las que tratamos regularmente. El estado también puede ser contenido directo:
- Todos los comentarios de un artículo y los detalles que los componen
- El artículo visto actualmente y todos sus metadatos
- Una variedad de artículos relacionados y los metadatos para esos
- Una lista de autores
- Un registro de actividad de las acciones recientes que ha realizado un usuario
React no lo ayuda a organizar ese estado, solo dice: Sé que necesita lidiar con el estado, así que llamémoslo estado y tengamos formas programáticas de establecer y obtener ese estado.
Antes de React, podríamos haber pensado en términos de estado, pero, en su mayor parte, no lo manejamos como un concepto directo.
¿Quizás has escuchado la frase “única fuente de verdad”? Muchas veces tratamos al DOM como nuestra única fuente de verdad. Por ejemplo, digamos que necesita saber si se puede enviar un formulario en su sitio web. Tal vez verifiques para ver si $(".form input[type="submit"]).is(":disabled")
porque toda su lógica comercial que se ocupaba de si el formulario podía enviarse o no, finalmente cambió el atributo deshabilitado de ese botón. Entonces, el botón se convirtió en esta fuente de verdad de facto para el estado de su aplicación.
O digamos que necesita averiguar el nombre del autor del primer comentario en un artículo. Tal vez escribirías $(".comments > ul > li:first > h3.comment-author).text()
porque el DOM es el único lugar que conoce esa información.
React nos dice un poco:
- Comencemos a pensar en todo eso como estado.
- Te haré una mejor: el estado es una parte de JSON, por lo que es fácil trabajar con él y probablemente funcione bien con tu back-end.
- Y uno más aún mejor: construyes tu HTML usando bits de ese estado, y no tendrás que lidiar con el DOM directamente en absoluto, me encargaré de todo eso por ti (y probablemente haga un trabajo mejor/más rápido que tú tendría.)
✅ Para Combatir Espaguetis.
Esto está muy relacionado con las cosas estatales de las que acabamos de hablar.
El código “espagueti” es cuando la organización y la estructura del código se te han escapado. Imagina, de nuevo, un formulario en tu sitio. Tiene algunas cosas de lógica empresarial que se ocupan específicamente de las entradas dentro de él. Tal vez haya una entrada de número que, cuando se cambia, muestra el resultado de algún cálculo al lado. El formulario también se puede enviar y debe validarse, por lo que tal vez ese código esté en una biblioteca de validación en otro lugar. Tal vez deshabilite el formulario hasta que esté seguro de que todo JavaScript se ha cargado en otro lugar, y esa lógica está en otro lugar. Tal vez cuando se envía el formulario, obtiene datos y eso necesita lógica y manejo. No hay nada terriblemente sorprendente aquí, pero puede ver cómo esto puede volverse confuso rápidamente. ¿Cómo un nuevo desarrollador en el proyecto, mirando ese formulario, razona todo lo que está sucediendo?
React fomenta el uso de construir cosas en módulos. Por lo tanto, es probable que este formulario sea un módulo propio o esté compuesto por otros módulos más pequeños. Cada uno de ellos manejaría la lógica que le es directamente relevante.
React dice: bueno, no vas a estar mirando el DOM directamente en busca de cambios y demás, porque el DOM es mío y no puedes trabajar con él directamente. ¿Por qué no empiezas a pensar en estas cosas como parte del estado, cambias de estado cuando lo necesitas, y yo me ocupo del resto, volviendo a renderizar lo que se necesita volver a renderizar?
Debe decirse que React en sí mismo no resuelve completamente los espaguetis. Todavía puedes tener estado en todo tipo de lugares extraños, nombrar cosas mal y conectar cosas de maneras extrañas.
En mi experiencia limitada, Redux es lo que realmente mata los espaguetis. Redux dice: Manejaré todo el estado importante, totalmente globalmente, no módulo por módulo. Yo soy la fuente absoluta de la verdad. Si necesita cambiar de estado, hay una gran ceremonia involucrada (lo he oído llamar así, y me gusta). Hay reductores y acciones despachadas y demás. Todos los cambios siguen a la ceremonia.
Si sigue el camino de Redux (y hay variaciones, por supuesto), termina con un código realmente sólido. Es mucho más difícil romper cosas y hay pistas claras a seguir sobre cómo se conecta todo.
✅ Mucha gestión de DOM.
El manejo manual del DOM es probablemente la principal causa del código espagueti.
- ¡Inyecte HTML aquí!
- ¡Arranca algo por aquí!
- ¡Cuidado con esta zona para este evento!
- ¡Ata un nuevo evento aquí!
- Nuevo contenido entrante! ¡Inyectar de nuevo! ¡Asegúrese de que tenga los enlaces de eventos correctos!
Todas estas cosas pueden suceder en cualquier momento y desde cualquier lugar en una aplicación que se ha vuelto espaguetis. Se ha renunciado a la organización real y se ha vuelto al DOM como fuente de la verdad. Es difícil saber exactamente qué está pasando con un elemento determinado, así que todo el mundo pregunta al DOM, hace lo que tiene que hacer y cruza los dedos para que no se meta con nadie más.
React dice: no puedes tratar con el DOM directamente. Tengo un DOM virtual y me ocupo de eso. Los eventos están vinculados directamente a los elementos, y si necesita que haga algo más allá de algo directamente manejable en este módulo, puede llamar ceremoniosamente a las cosas en módulos de orden superior, pero de esa manera, se puede seguir el rastro de la ruta de navegación .
La gestión DOM complicada es otra cosa. Imagina una aplicación de chat. Pueden aparecer nuevos mensajes de chat porque una base de datos en tiempo real tiene datos nuevos de otros usuarios del chat y han llegado algunos mensajes nuevos. ¡O usted mismo ha escrito un nuevo mensaje! O la página se está cargando por primera vez y los mensajes antiguos se extraen de un almacén de datos local para que tenga algo que ver de inmediato. Aquí está un hilo de twitter que conduce a ese hogar.
❌ Solo porque sí. Es el nuevo picor.
Aprender algo por aprender algo es asombroso. Haz eso.
Construir un proyecto para clientes y usuarios humanos reales requiere una consideración más cuidadosa.
Un blog, por ejemplo, probablemente no tenga ninguno de los problemas y no se ajuste a ninguno de los escenarios que harían que React encajara bien. Y debido a que no es una buena opción, probablemente sea una mala opción, porque introduce tecnología complicada y dependencias para algo que no lo requiere.
Y, sin embargo, zona gris. Si ese blog es un SPA (“Aplicación de página única”, por ejemplo, sin actualización del navegador) que se crea a partir de datos de un CMS sin cabeza y tiene una representación elegante del lado del servidor… bueno, tal vez ese sea el territorio de React nuevamente.
¿La aplicación web CMS que hace ese blog? Tal vez una buena opción para React, por todo el estado.
❌ Simplemente me gusta JavaScript y quiero escribir todo en JavaScript.
A la gente le dicen, diablos, le he dicho a la gente: aprende JavaScript. Es enorme. Alimenta todo tipo de cosas. Hay trabajos en él. No va de todos modos.
Solo en el historial web reciente es posible no salir nunca de JavaScript. Tienes Node.js en el lado del servidor. Hay un montón de proyectos que sacan CSS de la mezcla y manejan estilos a través de JavaScript. Y con React, tu HTML también está en JavaScript.
¡Todo JavaScript! ¡Salve JavaScript!
Eso es genial y todo eso, pero de nuevo, solo porque puedas no significa que debas hacerlo. No todos los proyectos requieren esto y, de hecho, lo más probable es que no lo requieran.
☯️ Eso es lo que sé.
(Hay emojis decentes para SÍ y NO, ¡pero QUIZÁS es más difícil!)
Estás aprendiendo. Impresionante. Todos son. Seguir aprendiendo. Cuanto más sepa, más decisiones informadas podrá tomar sobre qué tecnología usar.
Pero a veces tienes que construir con lo que sabes, así que no te voy a criticar por eso.
☯️ Ahí es donde están los trabajos.
No todo el mundo tiene una opinión directa sobre qué tecnología se utiliza en un proyecto determinado. Con suerte, con el tiempo, tendrá influencia en eso, pero eso lleva tiempo. Edén dice que ella pasó 2 años con Ember porque ahí estaban los trabajos. No hay daño en eso. A todo el mundo se le tiene que pagar, y Ember podría haber encajado perfectamente en esos proyectos.