Esta es una discusión que he tenido en bastantes ocasiones con pares y alumnos. La idea de este post es explicar un poco lo que se ha logrado con todas estas discusiones.
En muchos de los casos durante la universidad no hemos tenido la necesidad de desarrollar un software complejo, un software el cual deba de adaptarse a las necesidades del entorno, las modificaciones de ciertas librerías o simplemente al tiempo. La semana pasada le di el ejemplo a un alumno sobre codeignigter, en mi caso fue el primer framework que utilicé para desarrollo web utilizando php y actualmente ( no se si vaya a cambiar pronto) ya no es compatible con las nuevas versiones de php. Esto le puede pasar a cualquier desarrolo, la cantidad de actualizaciones, parches y modificaciones que salen anualmente son muchas más de las que podemos contar. Si esto le pasa a una aplicación que es mantenida por cientos de personas en la comunidad .. ¿Que nos espera a una aplicación desarrollada por nosotros ?
Ojo, esto no es para asustar a nadie, es simplemente para generar conciencia de lo que podría a pasar si no prevenimos.
Es solo cosa de mirar algunas de las aplicaciones más usadas del momento, como lo es Flickr y Facebook, ambas son en base a php y la verdad no creo que vayan a dejar de ser compatibles con sus nuevas versiones o no estén preparados para situaciones como esa. Deben de tener docenas si no cientos de desarrolladores con acceso al código que ocupan y tienen que además tener un estándar que seguir para publicar su código o simplemente para entender el que ya está escrito.
Lo bueno es que ya muchos desarrolladores han lidiado con los mismos problemas a los cuales podríamos enfrentarnos y han desarrollado frameworks en los cuales se han recopilado los conocimientos de muchos desarrolladores para hacer nuestras aplicaciones aún más fácil de realizar.
Ok, podemos decir que los frameworks están para hacer que un desarrollo complejo se convierta en un desarrollo simple. Es posible que para aplicaciones sencillas si agreguemos una complejidad innecesaria al implementar un framework, pero este post se basa en aplicaciones un poco más complejas, esas en las que se requiere ya de un equipo, en las que usaremos manejo de versiones, en las que dividiremos el código en hitos y cada uno de ellos se convertirá en un entregable de un proyecto.
Ok, ¿ pero que es un framework ?
Wikipedia : «A software framework is a universal, reusable software environment that provides particular functionality as part of a larger software platform to facilitate development of software applications, products and solutions. «
Personalmente me gusta el término de «un esqueleto que incluye lo básico para generar una aplicación compleja sin la complejidad requerida para realizarla«.
Si partimos de lo básico, un framework separa la lógica de las vistas, ordenando la forma en que desarrollaremos. De ahora en adelante hablaré un poco del Modelo Vista Controlador ( MVC ). En este modelo el framework provee una clara separación en 3 capas, y la posibilidad de interactuar entre ellas. Teniendo estas separaciones será muy difícil para nosotros desarrollar de manera inadecuada, aunque he visto casos que al no entender el concepto igual logran hacerlo pero se dan cuenta rápidamente que hay algo mal.
En general los frameworks se encargarán de conectar a la Base de datos por nosotros, se encargan que los datos sean accesibles por las vistas y algunos incluso nos facilitan la generación de código CRUD ( Create Read Update Delete ) para poner nuestra aplicación en marcha lo antes posible. Si tuvieramos que implementar esto por nuestra cuenta ( créanme tuve que hacerlo hace años atrás ) nos demoraríamos mucho tiempo y agregaríamos esa complejidad al desarrollo que tanto tratamos de ignorar. Teniendo esto en cuenta nosotros o nuestro equipo de puede enfocar simplemente en el desarrollo y éxito de la aplicación olvidándonos de desarrollo que cientos de personas ya han hecho por nosotros.
Hay dos frases que me gusta recalcar cuando hablamos de un framework :
- No reinventar la rueda
- Enanos parados sobre los hombros de gigantes. ( nanos gigantum humeris insidentes )
Ambas se refieren a lo lejos que podemos llegar basándonos en conocimiento ya escrito. ¡ Imagínense que sería de la física si tuviéramos que descubrir la ley de gravedad por cada científico que quisiera explicar por que una manzana se cae al piso ! Ahora piensa nuevamente por que quieres desarrollar algo que ya cientos de personas lo han hecho antes que tu, ¿ ahora suena más ridículo no ?
¿ Como elegir un framework ?
Les recomiendo que cumpla la mayoría de los puntos a continuación.
- Que sea sencillo de utilizar. La idea es simplificar, no hacer más complejo el desarrollo.
- Mejore el rendimiento de la aplicación. Muchos framework por ejemplo usan caché para mejor rendimiento.
- Asegure seguridad. Esto es muy importante y es una de las mejores razones de usar el framework.
- Separe el lenguaje de las vistas.
- Ojalá sea Orientada a Objetos !
- Habilidad de poder configurar
- Que tenga buena documentación.
- Que tenga una buena comunidad. La comunidad es la que te ayudará cuando tengas problemas.
Ok, espero que con todo lo anterior ya puedas decir que un framework si es necesario no importando el lenguaje que utilizarás. Yo hace un tiempo que uso Yii y me he estado portando a Yii2, cumple con todas las características que dije anteriormente y al parecer se ajusta muy bien a mi mindset, ahora la pregunta es ¿ cual framework usarás tu ?.
Sigo con Codeigniter, la han dado continuidad después de haberlo cedido al British Columbia Institute of Technology. Tengo harta simpatía por Laravel, pero en desarrollos de «menor escala», siento que Codeigniter ha sido mi caballito de batallas, liviano, sencillo y más un arsenal de helpers, y librerías adaptadas, sigue siendo la primera opción, sobre todo si se va a trabajar sólo o con poca colaboración.
Para proyectos más grandes, ahí tendería a usar algo no sólo MVC sino HMVC, aunque el que quiere puede (y en lo que sea).
Slds!
Que bueno que le dieron continuidad, hubiera sido una lastima con toda la comunidad que hay por detrás que lo hayan dejado de lado, pero aún así refuerza la tesis de que hay que usar un Framework avalado y mantenido por la comunidad.
Gracias por el dato !
¿Qué sucedería si el framework que utilizo llegase a ser obsoleto (comienza a quedar en el olvido) y ya deja de ser compatible con las nuevas versiones de php?
En ocasiones sucede que si actualizo a la versión más reciente del framework ya el código que tenía escrito no es compatible con la versión nueva y comienzan a aparecer errores, entonces ya no es sólo el tiempo que tienes que disponer para aprender el framework, sino el tiempo que tienes que disponer para actualizar el código y hacer que se ajuste a la versión más reciente del framework.
Por otra parte el framework podría limitarte sólo a lo que hace el framework.