71

React vs. Angular vs. Vue vs. Svelte | ¿Cómo elegir tu próxima herramienta frontend? ¿Cuál es mejor?

212889Puntos

hace 3 años

React es una librería de JavaScript para construir interfaces de usuario con componentes. Trabaja junto a muchas otras herramientas para crear aplicaciones web completas.

Vue.js es un framework progresivo. Nos permite integrarlo poco a poco en nuestras aplicaciones web hasta llegar al 100% y aprovechar todo su potencial (junto a todo su ecosistema).

Angular es un framework para desarrollar una aplicación web moderna de 0 a 100 con (casi) todas las funcionalidades que podrían necesitar y (casi) sin ayuda de otras herramientas extra.

Svelte es un compilador. No se considera tanto un framework o una librería, sino una herramienta donde escribimos todo nuestro código frontend que se convertirá en JavaScript muy optimizado.

Frameworks vs. librerías

Hacer comparaciones entre frameworks y librerías no es del todo justo.

Una librería es inevitablemente más fácil de aprender que un framework por tener un rango de funcionalidades mucho más pequeño. Y un framework es inevitablemente más robusto precisamente por lo contrario, abarca un montón de funcionalidades de las que una librería no se hace responsable, sino que delega a alguna otra librería.

En este blogpost analizaremos las características, ventajas, desventajas y diferencias entre estas 4 herramientas. Pero no de forma independiente, sino en conjunto con su ecosistema de herramientas relacionadas más cercanas y populares.

¡Que empiece la batalla entre las 4 herramientas más populares del desarrollo frontend!

We are at war

Aprende a usar todos estos frameworks y más con los cursos full stack developer en Platzi.

¿Cuál es el mejor framework o librería de JavaScript?

No existe. La elección es completamente tu responsabilidad dependiendo de tus ambiciones profesionales y el proyecto que piensas desarrollar.

  • ¿Buscas la mayor demanda laboral?

Aprende React.js y su ecosistema principal de tecnologías en la [Ruta Profesional de JavaScript](Escuela de JavaScript), el camino más corto para convertirte en Full Stack Developer.

  • ¿Buscas la menor curva de aprendizaje?

Aprende Vue.js o Svelte. Incluso React.js. Su sintaxis es mucho más familiar (y menos aterradora) para personas que conocen HTML y poco a poco va incrementando su dificultad en JavaScript.

En comparación, React requiere un poco más de conocimiento en JavaScript para empezar. Y Angular desde el principio va a hacerte sufrir amargamente (con muchos beneficios a largo plazo, pero también algunos traumas al inicio).

  • ¿Buscas el mejor rendimiento para tu aplicación?

Rendimiento es un concepto un poco… difícil de definir.

Te mentiría si digo que X ofrece el mejor rendimiento porque esos resultados cambiarán con cada nueva versión, actualización o caso de uso de tu herramienta.

Más bien, aprende a configurar la optimización de tus aplicaciones con empaquetadores web: Webpack vs. Parcel vs. Rollup vs. ESBuild | Empaquetadores de JavaScript.

  • ¿Buscas una herramienta 100% reactiva?

Aprende Vue.js o Svelte, son 100% reactivos de forma nativa y por defecto. Incluso Angular, se integra muy bien con RxJS, la herramienta por excelencia para trabajar con el paradigma de programación reactiva.

React no es 100% reactivo (sí, qué irónico).

  • ¿Buscas opiniones fuertes acerca de estrategias de render?

React y Vue usan el Virtual DOM. Angular y Svelte usan estrategias de render diferentes, aunque ambos manipulan el DOM directamente.

No hay ganadores en este punto. La calificación depende completamente de tu percepción sobre la mítica pelea del DOM vs. Virtual DOM (y las estrategias de render en la web).

  • ¿Buscas dificultad al principio a cambio de mucha facilidad en el futuro?

Aprende Angular. Al ser un framework tiene una curva de aprendizaje bastante alta al principio, pero luego de dominarlo te brindará todo lo que necesitas para construir aplicaciones web en el menor tiempo posible.

Las demás herramientas, por ser librerías, requieren mayor tiempo de configuración y curva de aprendizaje para integrar el resto de librerías de su ecosistema.

Te recomiendo tomar el Curso de Frameworks y Librerías de JavaScript para conocer el ecosistema del desarrollo web moderno y el flujo de trabajo de aplicaciones web con JavaScript. No solo estudiaremos herramientas de UI, sino también algunos conceptos – introductorios y avanzados al mismo tiempo 😅 – como reactividad, empaquetadores, manejo del estado, routing y CSS-in-JS.

Además, cuéntame en los comentarios cuál herramienta elegiste aprender (o cuáles piensas elegir) y por qué. 😏

💡⚛ Yo escogí React.js y quiero enseñártelo en el Curso de Introducción a React.js.

No sobra pedir que mantengas el respeto por encima de cualquier opinión diferente a la tuya. Yo sé que este es un tema sensible, pero sé fuerte y mantente fiel al #NuncaParesDeAprender. 🤓💚

GIF war
Juan
Juan
juandc

212889Puntos

hace 3 años

Todas sus entradas
Escribe tu comentario
+ 2
Ordenar por:
10
24288Puntos

Hay algo que me llama mucho la atención en esto, es cierto que React tiene una curva de aprendizaje más sencilla pero requiere de más trabajo para configurarlo adecuadamente con sus herramientas y el uso adecuado de webpack, el problema que veo con React es que no te ofrece una forma estándar de hacer las cosas y eso sin duda es algo muy caótico, incluso en los cursos de platzi se ve, cada quien hace lo que quiere o mejor dicho, como quiere.

Ahora si nos vamos a Angular por ser un framework ya tiene una estructura definida e incluso tiene un manual de estilo donde te dicen the angular way, la forma correcta de hacer las cosas, ya te estructura el proyecto bsse y de ahí ya depende de ti como quieras ordenar tu aplicación.

A la larga es más mantenible porque solo te toca ver como se hace algo en angular y ya de ahí implementarlo, toda la documentación que existe en la web es inmensamente mayor a la de React y por lo que dije antes la documentación de angular es consistente a diferencia de la de React.

En los casi 8 años que llevo trabajando con angular es lo que he podido notar al respecto a diferencia de React

1
20969Puntos
2 años

Que interesante percepción y forma de mostrarlo. Muchas gracias por compartirlo con todos.

2
2248Puntos
2 años

Recien estoy tomando cursos de Angular y me interesa. Buen dato, me animo a seguir aprendiendo mas acerca de Angular. Muchas Gracias!

9
70053Puntos

Buen artículo!
Hoy todo el mundo aprender React y vamos camino a que haya miles de programadores junior React/NodeJS. EL 95% de los bootcaps que veo son de esas tecnologías.
El día de mañana la demanda laboral de Angular/Vue será muy alta y terminarán siendo los programadores mejor pagos por la escases. Svelte no lo cuento porque jamás vi una propuesta laboral de Svelte. Pienso que es un poco la tendencia hacia donde vamos.
Saludos!

9
224341Puntos
3 años

La landing page de Spotify está construida en Svelte, así que yo no lo descartaría tanto 👀 jaja

2
70053Puntos
3 años

Gran dato! no sabía eso.
De todas formas, Svelte es hoy una tecnología para divertice y conocer más de JS, no tiene prácticamente salida laboral. Pero es buen momento para aprenderla ya que de acá a unos años, no se sabe.
Saludos!

1
6738Puntos
3 años

Entonces Kevin, tu recomendarías acercarse a React y a Angular? o a NodeJS y Vue? o que combinación dirías que es mejor para una mejor proyección a futuro?

3
70053Puntos
3 años

Pensando a futuro, tanto con React como con Angular tienes salida laboral asegurada durante varios años.
Con Vue también, en menor medida.
Con NodeJS también es garantía, pero eso ya es backend.
Al menos lo que veo yo que se solicita, laboralmente, en Argentina.
Saludos!

4
943Puntos
3 años

No lo creo amigo un ejemplo es JAVA hay muchísimos desarrolladores JAVA en el mundo, prácticamente en la mayoría de las universidades va de cajón si o si; y aun así, habiendo una cantidad bastante grande de especialistas en este lenguaje existe mucha demanda de trabajo y el mercado no para de solicitar más. Lo mismo esta pasando con JS/React/Node/Angular/Vue y compañia.

6
36363Puntos

Yo la hice sencilla. Realice el curso de Frameworks y Librerías de JS, luego de tener un pantallazo de cada uno, directamente decidi asi: Svelte -> Vue -> React | Angular decidiendo al final sobre si hacer React o Angular.
Pero luego de hacer el curso, notas cual es más sencillo que el otro y ese viene siendo mi camino.
Ahora sí, Svelte y Sapper que es lo único que hay hoy en Platzi para Svelte, esta desactuliazado (no quiere decir que no sirva nada hacerlo los cursos), Sapper dejo de ser mantenido y ahora estan enfocados en SveltKit pero igualmente hacer los cursos (son solo 3) sirven un montón para abrirte la mente.
Luego de VueJS y de ReactJS hay para tirar para arriba, asi que hay que meterle!

Mi recomendación por curva de aprendizaje más que por salida laboral (si tienen tiempo, obvio) es esa: Svelte -> Vue -> React | Angular

Muchos éxitos 😃

3

Bueno si pueden manejar angular y react … está bien los dos… si hay que escoger uno prefiero angular, solo cuestión de gustos…
Ya en un proyecto empresarial dependerá de las habilidades del equipo.
Saludos

3
58767Puntos

Buen artículo, gracias por compartirlo.

3
21475Puntos

Yo creo que React es de lo mejor que hay ahora mismo, prácticamente es Javascript en sí mismo, y es de los que mejor rendimiento puede tener. Para mí la forma de hacer frontend más completa. Aunque Vue me llama la atención.

2
32883Puntos

Muy buen articulo y es verdad que React tiene mas solicitud en el mundo laboral

2
25929Puntos

Excelente blog gracias JuanDC, Creo que por algo el lema de Platzi es nunca pares de aprender, yo estoy iniciando y creo que me voy a ir por React pero mas adelante quiero aprender Angular, el saber uno no hace que no puedas aprender los demás y no digo que aprender un poquito de todo, sino aprender uno trabajarlo practicarlo e incluso usarlo en el campo laboral y luego cuando ya este trabajando ir aprendiendo el otro y asi seguir creciendo!

2
5620Puntos

Acabo de terminar el curso de JavaScript y no sabia por donde continuar, gracias por esta información.

2
23048Puntos

Hace un par de years atrás, un texto como este equivalía a guerra hahaha.
En mi caso, algo se de Angular y ahora ire por React ;0

2
54448Puntos

Yo no quisiera decidirme por uno solo, pero el camino de React creo que es para mí y luego más adelante Vue.js pero debo admitir que disfruté mucho el curso de Svelte

2
13800Puntos

Excelente artículo, no puedo esperar a que salga el curso de Introducción que dicta @juandc, ya que es el que más me llama la atención y el que quiero empezar a aprender!

2
7449Puntos

Aprenderé React porque igual me toca 🤭 pero en un futuro me arriesgaré con Angular

2
57506Puntos

Que gran articulo, ahora tengo algo más claro qué elegir, y pienso elegir React, aunque quisiera aprender más de una.

2
34844Puntos

Muchas gracias profe juan, por ayudarnos a explicar más fácil todo esto, espero con gusto el curso, creo que seguiré su consejo y empezare con react.js.

2
48243Puntos

Excelente artículo Juan, quiero aprender React aunque aun sigo con los cursos de JavaScript 😁

1

No pretendo conseguir empleo como desarroyador. me gustaria una herramienta con curva de aprendizaje baja… me llama mucho la atencion construir una app para comercio electronico . cual de las cuatro me recomiendan ? les agradesco mucho su sugerencia

1

hola, tengo mi inquietud a pesar de este gran aporte de guía, porque no sé cual lenguaje escoger entre react, vue, angular o java?

1
57506Puntos
2 años

Hola! React, Angular, Vue y Svelte no son lenguajes, en pocas palabras son superpoderes para su propio lenguaje de programación, que en este caso es JavaScript.

Java es un lenguaje de programación pero es diferente a JavaScript. 😛

Dicho esto, y después de que hayas leído el gran articulo del gran profe Juan. Ya entenderás que ninguno es mejor que otro, cada uno tiene sus pros y sus contras.

La teoría dice que una vez entiendas muy bien JavaScript empieces por Svelte o Vue, porque su curva de aprendizaje es más amigable al que recién está iniciando, después React o Angular. React es el que tiene más demanda laboral. Angular al final porque es un framework hecho y derecho, es más completo y por ende hay más que estudiar.

En conclusión, elije el que gustes, pero empieza, y lo más importante de todo… Nunca pares de aprender.

Espero haberte aclarado un poquito más tus dudas :DD

1

aunque laboralmente he visto demanda de angular y java pero ahi sigue uno con la inquietud jajajajjjaaj

1
10429Puntos

Hace poco anunciaron que angular va a dejar de tener soporte asi que va a ir perdiendo cuota de mercado probablemente.

5
212889Puntos
3 años

Angular no dejó de tener soporte, sino Angular.js (la versión más vieja de Angular). No va a perder mercado para nada.

1
12076Puntos

Por que Vue aun no es tan demandada laboralmente como Angular y React? sabiendo que en funcionalidades esta a la par y se adapta muy rapido a los cambios?

3
212889Puntos
3 años

Facebook crece con React, React crece con Facebook.
Vue es gigante, pero el soporte directo de Facebook es inevitablemente MUY atractivo para las empresas (por lo que hay bastante demanda laboral). Principalmente es por eso.