Gallery
Ultima Laravel
Share
Explore

Creamos un nuevo proyecto laravel
composer create-project laravel/laravel colegio

Vamos a crear la BD colegio que va a tener la tabla Alumno
image.png
En el fichero .env
image.png

Migraciones

Creamos la migración de la tabla
Si queremos hacer la migración y el modelo a la vez ( tened en cuenta que se va a crear siguiendo las convenciones de laravel: nombre del modelo.- en nuestro caso será Alumno y la tabla asociada a ese modelo sera alumnos)
image.png

Vamos a las migraciones, donde se ha creado una nueva para alumnos (la tabla es alumnos)
image.png
Que contiene
una clave de identificación (por defecto autoincrementable)
dos columnas ( created_at y updated_at ) creadas por el método de marcas de tiempo .
image.png
Vamos a modificar la tabla con los campos que queremos
image.png
Para ejecutar la migración creada
image.png
En la BD
image.png
image.png
La tabla alumnos
image.png

Seeder Alumno

image.png
Añadimos la referencia de la clase Alumno:
image.png
Creamos la variable $alumno, llenamos sus propiedades y finalmente utilizamos el método save(); igualmente llenamos con tres registros nuestra tabla alumnos.
image.png
Cuando ejecutamos los Seeders desde Artisan, este llama a la única clase que es DatabaseSeeder. Por lo tanto para ejecutar los demás Seeders creados debemos instanciar a esta clase con el método call().
image.png
Ejecutar Seeders
Ya podemos cargar de datos la tabla de nuestra base de datos Ejecutamos la siguiente línea de código que llenará las tablas con datos.
Para verificar los cambios en la base de datos, me voy a lo que es phpMyAdmin desde mi navegador, actualizo la página, abrimos la tabla y podemos verificar que los datos que definimos en los Seeders se encuentran cargados.
image.png

En la BD la tabla alumnos
image.png

Factories en Laravel

Con los Seeders que nos proporciona Laravel ya podemos llenar la tablas de nuestra base de datos. Sin embargo, es limitado ya que, si queremos llenar más de 10, 100 registros sería prácticamente un ejerció en sufrimiento. Porque se crea una variable por cada registro de la tabla.
Por esta razón Laravel cuenta con los Factories que es otra forma de llenar los datos de una forma más automatizada, y generar gran cantidad de datos.
Los Factories son sencillos de utilizar, solo se debe especificar en cada campo de la tabla que tipo de dato se quiere llenar, posteriormente la cantidad de registros que se quiere generar en la tabla.
Factory Alumnos
Ahora lo primero que aremos es crear nuestra clase AlumnoFactory con Artisan escribimos la siguiente línea de código.
image.png
Crea AlumnoFactory.com
image.png
image.png
Modificamos
image.png
Y cambiamos en el DatabaseSeeder
image.png
Ejecutamos seeders
image.png
image.png
image.png

Modelo

Si solo hacemos el modelo
Si usamos el modelo con –a (para que cree modelo, migración, seeder, Factory y controlador resource
Con la instrucción utilizada en el ejercicio
Ha creado el modelo Alumno
image.png
Con el código:
image.png
Registramos las configuraciones de la tabla Alumnos.
Lo modificamos
image.png
Si es necesario podemos hacer public $timestamps = false;
Podemos crear funciones . Ejemplo
La función “Obteneralumnos” utiliza el método all() para obtener todo el listado de los alumnos de la tabla.
La función “ObtenerAlumnoPorId” utiliza el método find() pasando un parámetro Id para obtener a un determinado alumno.
que podrían estar en el modelo
image.png

Controladores

Crear Controlador alumnos
Si queremos que se creen todas las funciones necesarias para un CRUD
image.png
image.png
Se creará todos los métodos que necesitamos
image.png
Lo primero que haremos es llamar a la referencia del modeloAlumno .
Dentro de la función index escribimos la siguiente consulta.
image.png
De igual forma obtendremos todos los datos de la tabla alumnos. Seguidamente, retornaremos en la variable $alumnos a la vista alumnos.
Podemos hacer también con la instrucción
image.png
Crear ruta
Seguidamente, vamos a crear la ruta, trabajaremos con el archivo web.php que se encuentra en el directorio routes.
En primer lugar, se debe hacer referencia al controlador:
En segundo lugar, crearemos las rutas de tipo get que harán la referencia al método index de nuestro controlador. Por último, le asignamos un nombre a nuestra ruta.
image.png

Plantillas Blade

Crear vista alumnos
Crear la carpeta alumnos y dentro de este creamos el archivo index.blade.php , introducimos el código de la vista alumnos finalizar también añadimos el código css para mejorar un poco el diseño de la vista.
image.png
Si vamos a http://localhost/nombreproyecto/public/alumnos nos muestra el resultado
image.png
Paginación
Vamos a paginar esta vista
En el controlador, aquí también ponemos otra forma de pasar datos (compact)
image.png
Si queremos ordenarlos
image.png
y en la vista ponemos el enlace
image.png
Ahora la vista será
image.png
Nota
Posible Error de visualización→ del botón de la paginación sale inmenso
image.png
Es debido a que Laravel usa la paginación Tailwind para cambiar esto dirígete a:
image.png
Y agrega el siguiente use
Y dentro de la parte de la función boot
Quedaría
Documentación
Otra forma puede ser:
laravel para paginar utiliza el Tailwind CSS y debes cambiarlo a Bootstrap, para esto utiliza el comando
Y luego puedes personalizar las vistas generadas en resources/views/vendor/pagination/ o cambiar la vista por defecto a una que prefieras de Bootstrap en tu vista seria así:
Nota :Versión 9
Bootstrap 5 Pagination Views
Laravel ahora incluye vistas de paginación creadas con Bootstrap 5. Para usar estas vistas en lugar de las vistas predeterminadas de Tailwind, puede llamar al método useBootstrapFive del paginador dentro del método boot de su clase App\Providers\AppServiceProvider:
image.png

Método create y store

Vamos con los métodos de create() y store() del controlador AlumnoController.
En el método create() escribimos el siguiente código:
image.png
En el método store() el siguiente código:
image.png

Rutas web (create y store)

Ahora crearemos las rutas de tipo de create() y store() que harán la referencia al método get() y post() de nuestro controlador.
Primero abrimos nuestro archivo web.php, las funciones get() y post() se encargaran de realizar las peticiones a los métodos de nuestro controlador Alumno.
image.png

Formularios Blade (crear alumno)

Ahora crearemos los formularios en las vistas, utilizaremos las plantillas Blade que te ofrece Laravel.
Para la navegabilidad entre ventanas en los archivos index de Alumnos y añadiremos un enlace que cuando hagamos clic redireccione al formulario de crear, en mi caso yo le colocaré antes del título de la vista.
image.png
Quedando
image.png
Formulario crear Alumnos
Laravel te exige un @csrf Token con el propósito de prevenir posibles ataques a las peticiones solicitadas en formularios HTML.
Realizamos los mismos pasos al crear el formulario de la vista alumnos. Primero creamos el archivo crear.blade.php en la ruta resources/views/alumnos y escribimos el siguiente código:
image.png
vamos a poner el css de momento en la misma vista
nos quedará
image.png

Método edit y update

En el método edit() del controlador AlumnoController haremos lo siguiente. Primeramente, con el método findOrFail($id) recuperamos un determinado registro con un identificador $Id que le pasamos como parámetro, seguidamente retornaremos a nuestra vista del formulario alumno con el variable $alumno
En el método Edit() introducimos el siguiente código:
image.png

En el método update() el siguiente código:
image.png

Rutas para actualizar (edit y update)

Ahora crearemos las rutas para actualizar registros de nuestra base de datos, similar como lo realizamos al crear un nuevo registro.
En el archivo web.php utilizaremos las funciones get() y put() escribimos el siguiente código:
image.png

Formulario Actualizar(edit y update)

Para actualizar los datos de las tablas de nuestra base de datos. Primeramente, agregamos la navegabilidad en nuestras vistas del listado Alumnos.
En el archivo index de la vista alumnos, en la cabecera de la tabla añadimos el siguiente código:
Dentro del bucle foreach lo siguiente:
image.png
Formulario actualizar alumnos
En el formulario de edición de alumnos realizamos los mismo pasos. De igual forma, crearemos el archivo editar.blade.php en el directorio resources/views/alumnos, y escribimos el siguiente código:
image.png
Ponemos css
image.png

Validar formularios

Laravel ya viene integrado funciones que podemos utilizar para validar nuestros formularios antes de guardar en nuestra base de datos.
Antes de crear nuestras validaciones, primero abriremos las migraciones creadas anteriormente. Por ello, verificaremos en los campos el tipo de dato si es entero, cadena o fecha, seguidamente observamos que campos son obligatorios y que campos son opcionales.
image.png
Ahora abriremos nuestro controlador AlumnoController, en el método store() es donde se controlan los errores de validación de nuestro formulario, es aquí donde añadiremos código a las validaciones, antes de crear una nueva instancia de alumnos.
Utilizaremos la variable request que es pasado como parámetro de la función store que contiene todos los campos del formulario, al método validate() le pasamos un array con los campos del formulario y sus validaciones respectivas.
Laravel nos indica en caso de que algunas de las validaciones realizadas no cumplen con la condición retorna a la vista un error de validación y no pasa a la siguiente línea de código del programa. Sin embargo, si todas las validación hechas se cumplen entonces pasa a la siguiente línea de código, en nuestros ejemplo crea la nueva instancia alumno, carga los datos y posteriormente guarda los datos en nuestra base de datos.
image.png

Impresión de errores de validación en formularios

Ahora pasamos a la vista de nuestros formularios, es aquí donde vamos a imprimir mensajes en los campos del formulario cuando existan errores de validación que definimos en nuestros controladores.
Antes de comenzar con la validación de los formularios añadiremos código css a todas nuestras vistas, con el fin de dar estilo a los mensajes de error.
Validación del formulario en la vista alumnos
Empecemos a validar el formulario alumnos, abrimos el archivo crear.blade.php que se encuentra en la ruta resources/views/alumnos, donde iremos integrando todas nuestras validaciones.
En el campo Nombre y Apellidos por debajo del elemento input añadimos el código de validación de este campo con la directiva que nos ofrece Blade, @error nos permite imprimir el mensaje de error que corresponde a este campo.
Ahora vamos a añadir el método old() (Es una directiva de Blade) en las etiquetas input de nuestro formulario, este método lo que hace es mantener en los campos el texto escrito por el usuario en caso de error de validación en uno de ellos.
Ahora en el campo edad añadimos las validaciones.
Igualmente, el método old() a la etiqueta input del campo edad
En el campo teléfono escribiremos lo siguiente:
En el campo dirección escribiremos lo siguiente:


image.png
image.png

Traducir al español los mensajes de validación en Laravel

Si observamos al momento de probar nuestro código los mensajes de error de validación en los formularios están en inglés, debido a que la configuración de Laravel viene por defecto en inglés.
Para poder configurar nuestra aplicación en español tenemos que realizar los siguiente:
Primeramente en la ruta lang creamos una carpeta llamada es, ahora copiamos todos los archivos que se encuentran en la carpeta en y lo pegamos en la carpeta creada es.
image.png
La comunidad de Laravel ya cuenta con un repositorio en esta donde tiene traducido los mensajes en varios idiomas entre ellos el español.
Si queremos mas idiomas
Configuración del archivo config
Por último debemos indicar a Laravel que utilizaremos las configuración de lenguaje en español, en la carpeta config abrimos el archivo app.php, buscamos la siguiente línea de código ‘locale’ => ‘es’ y reemplazamos es por en.
image.png
Cambiamos y queda
image.png

Actualizamos nuestro navegador y probamos las validaciones con la nueva configuración, todos los mensajes por defecto estarán ahora en español.
image.png
Traducción de variables en Laravel
Ya solucionamos parte de los mensajes de error de validaciones, si observamos con más detalle los mensajes de error, El campo nombre apellido es obligatorio y lo correcto debe ser El campo Nombre y Apellido es obligatorio.
Este caso nos ocurrirá bastante si las variables que declaremos estén en inglés que generalmente se declaran de esta manera, para solucionar este problema nos dirigimos al directorio creado que está en resources/lang/en abrimos el archivo validation.php y dentro de la variable attributes declaramos las variables de nuestro formulario que queremos corregir.
image.png
modificamos:
Queda
image.png
image.png

Visualizar registros (show)

Cuando necesitamos ver una gran cantidad de información de un registro en específico nos viene muy bien tener una ventana independiente donde poder visualizar todos estos datos.
Método ver en controlador alumnos
Iniciamos abriendo el controlador AlumnoController, dentro del método show() iniciamos una variable $alumno que obtendrá un objeto de tipo Alumno, al método findOrFail le pasamos un parámetro Id para recuperar un registro en particular, finalmente retornamos a la vista ver el alumno con los datos recuperados.
image.png
Ruta web de la vista ver
image.png
Vista Blade show
Finalmente pasamos a las vistas de visualización de datos de un determinado registro de nuestra base de datos, para la navegabilidad entre ventanas en los archivos index
En el archivo index de la vista alumnos igual añadimos el siguiente código:
image.png
Formulario ver alumnos
En la ruta resources/views/alumnos creamos un nuevo archivo ver.blade.php y dentro definimos la vista ver donde visualizamos todos los datos de un registro en específico.
image.png
image.png
image.png

Método destroy

Abrimos el controlador AlumnoController, dentro del método destroy() , llamó al método delete() del objeto $profesor para eliminar el registro de nuestra base de datos.
image.png
Ruta web de la vista eliminar
image.png
Eliminar registros en Laravel
Finalmente pasamos a la funcionalidad de eliminar, utilizaremos la vista ver creada anteriormente donde iremos añadiendo código que nos permita eliminar un registro seleccionado con algunos controles y validaciones que se tiene que tomar en cuenta.
En el caso tener mas tablas tendremos que realizar las validaciones que tomaremos en cuenta que son por ejemplo un alumno no puede ser eliminado si está inscrito en uno o varios cursos.
Vista eliminar alumnos
En el archivo index.blade.php de la ruta resources/views/alumnos

Vamos a ponerlo en orden todas las opciones
image.png
También puedo poner
y voy a meter el css en el fichero style.css que esta en resources/css
image.png
image.png
y utilizo bootstrap para usar en enlaces y botones
image.png
image.png

Confirmar borrado o cancelar

Vamos a cambiar el borrado de nuestro alumno, realizando la confirmación de la baja.
Modificamos el index , poniendo al formulario como comentario

Empezamos poniendo una ruta para esa confirmación
image.png
En el controlador creamos nuevo método

y modificamos

image.png
que sera
image.png
Nos falta la vista confirmar
image.png

image.png

Nos falta la ruta cancelar, que puede ser ( he creado una ruta para cancelar, pero podriamos mandarla directamente an index)
image.png
podemos tener dos aviso:
Cuando borra correctamente al alumno
image.png
o si lo cancela
image.png
Para que muestre los mensajes cambiar en el index

image.png

Rutas resource y controlador

Si en este momento web.php tiene las siguientes rutas que hemos creado para hacer un crud de nuestra tabla alumnos
image.png
Cada una de estas rutas nos manda al método correspondiente en el controlador AlumnoController.
También podemos ver las rutas mediante el comando artisan
image.png

image.png
Podemos cambiar todas estas rutas por las que nos da la siguiente
image.png
Podemos comprobar que nuestro sitio sigue funcionando como antes
Esto se hace cuando al crear el controlador hemos creado todas las rutas necesarias para hacer el CRUD de la tabla
image.png
Variaciones
Cuando creamos el Controlador
image.png
Me crea algunos de los métodos pasando el modelo, en vez de el Request
image.png
El controlador quedaria

Middleware


Para crear un nuevo middleware, use el make:middleware comando Artisan:
image.png
Este comando colocará una nueva DomingoMiddleware clase dentro de su app/Http/Middleware directorio.Nuestro middleware s se encargará de hacer cosas cuando detecte que el día actual es un domingo. Ese comando de artisan genera un middleware básico en el que solo tenemos un método. En este middleware, sse encargará de hacer cosas cuando detecte que el día actual es un domingo
image.png
image.png
Ponemos:
Quedando
image.png
Sobre el código anterior queremos que te fijes en el método handle(), que es el que se ejecutará cuando se ponga en marcha este middleware. Con el if se comprueba si el día de la semana actual es domingo, realizando dos acciones distintas si era o no era ese día de la semana.
Registrar el middleware de manera global
Ahora vamos a registrar el middleware para ver cómo se ejecuta en el sistema. Empezaremos registrando en modo global, para que se ejecute en todas y cada una de las solicitudes que atienda nuestra aplicación.
Esto es muy sencillo , se hace desde el archivo Kernel.php que está en la ruta app/Http/Kernel.php.
Hay una propiedad de la clase Kernel donde se coloca toda la lista de middleware a ejecutar de manera global;
image.png
Como puedes ver, es un array en el que debemos indicar el listado de los middleware a ejecutar en cada solicitud, en el orden en el que van a ser invocados. Nosotros hemos agregado el middleware creado anteriormente en el último elemento de la lista, pero si necesitase mayor prioridad sería solo ponerlo antes en el array.
Una vez registrado el middleware de manera global podrías entrar en cualquier página de la aplicación y debería verse la salida del middleware, informando si es o no domingo.
image.png
Registrar el middleware para una ruta determinada o un controlador
Hay varias maneras de hacer este paso, desde el sistema de rutas o incluso desde los controladores, pero siempre debemos comenzar por asignar un nombre a nuestro middleware en el archivo Kernel.php. Allí, en la clase Kernel, hay una segunda propiedad llamada $routeMiddleware, donde tenemos un array asociativo con los middlewares que deseemos usar en las rutas.
Cada elemento del array tiene un índice y ese índice será el nombre que le demos al middleware para referirnos a él desde el sistema de routing.
image.png
Ahora podemos ejecutar el middleware a través del índice que le hemos dado en el array anterior. Lo veremos hacer mediante tres alternativas distintas:
Desde el sistema de routing, al definir la ruta, podemos indicar un middleware que queremos usar. Esto lo tenemos que hacer desde el registro de rutas, realizado en el archivo routes.php, mediante una sintaxis como la que puedes ver a continuación.
image.png
image.png
2. También desde el sistema de routing podemos generar un grupo de rutas donde se ejecute este middleware.
image.png
image.png
Así hemos indicado dos rutas donde se ejecutará ese middleware etiquetado como "domingo".
3. Desde un controlador también podemos llamar a un middleware. Lo podemos hacer desde el constructor, por lo que ese middleware afectará a todas las acciones dentro del controlador.
image.png
En este caso no necesitamos mencionar el middleware desde el sistema de rutas, solo lo mencionamos desde el constructor del controlador, para ejecutarse en cualquiera de las acciones declaradas en él.

image.png
image.png
Encadenar un middleware con el siguiente
Según la filosofía de los middlewares en Laravel,pueden existir varios que se ejecuten en cadena, uno detrás de otro, para cada solicitud. Por ello tenemos que asegurarnos que este encadenamiento se pueda producir. Realmente este trabajo nos lo dan ya hecho en el middleware que se genera con artisan, por lo que no debemos preocuparnos nosotros. Sin embargo queremos que se vea dónde se consigue ese procesamiento en cadena.
Echemos un vistazo al método handle() del middleware generado automáticamente:
Como se puede ver, en este método se devuelve con return una llamada a $next() pasándole $request como parámetro. Esa llamada es la que permite que se ejecute el siguiente middleware en la lista de middlewares globales y además enviarle la Request completa al siguiente middleware para que siga filtrándola.
Realmente no tenemos que hacer nada manualmente, porque Laravel ya le pasa en el método handle el $request y el $next como parámetro. Además, Laravel sabe si ese middleware es el último de la lista, en cuyo caso no debería haber otro encadenamiento. Simplemente sería asegurarse de dejar ese return que aparece de manera predeterminada, para que todo siga funcionando.


Plantillas y menú

Blade es un poderoso motor de plantillas de Laravel que permite introducir código PHP en plantillas HTML de una manera sencilla y segura, permitiendo separar bloques de código que se pueden reutilizar en distintas vistas de tu aplicación.
Separar los estilos css de las vistas
Vamos a separar los estilos de todas nuestras vistas en un solo archivo; en el directorio public/ crearemos una carpeta llamada css y dentro de éste, un archivo llamado main.css.
image.png
Por último, reemplazamos el código css de todas las vistas por la ruta de nuestro archivo de estilos main.css. Colocamos una etiqueta link y con la palabra asset se especifica la ruta css/main.css
image.png

Crear menú en Blade

Crearemos un menú principal de navegabilidad con la finalidad de ir de una ventana a otra sin la necesidad de escribir la URL de cada ruta en el navegador.
Estilos css
Para dar estilo al menú principal, lo primero que deberemos hacer es copiar el código css en nuestro archivo main.css.
Crear menú principal en vistas​​
Ahora vamos a crear el menú en nuestras vistas, en el archivo index de la ruta resources/views/alumnos debajo de la apertura de la etiqueta body copiar el siguiente código:
Si no tienes creados todavía profesores y cursos
image.png

Este proceso lo repetiremos en todas nuestras vistas de profesores, alumnos y cursos. Seguidamente, abrimos nuestra aplicación en el navegador, donde ya podemos visualizar el menú principal.
Pero este código no es óptimo. Ya que, si queremos aumentar una opción a nuestro menú por ejemplo categorías de cursos, lo que se tendría que hacer es ir a todas nuestras vistas y modificar el menú de cada uno. Por esta razón, Laravel te ofrece herramientas como Blade para optimizar las vistas.

Layout Blade utilizando herencia de plantilla

Los diseños (layouts) se crean mediante herencia de plantillas que es uno de los beneficios que te ofrece Blade. Nuestras vistas mantienen el mismo diseño en todas sus páginas. Blade nos sugiere crear una plantilla principal (Master) de donde las demás vistas hereden sus características comunes.
Crear plantilla principal
Empecemos a optimizar nuestras vistas. En primer lugar, creamos un archivo master.blade.php en la carpeta layouts en ruta resources/views que será nuestra plantilla principal.
image.png
Seguidamente, será copiar todo el código de la vista index del controlador AlumnoController y pegar en el archivo master. Finalmente, borramos todo el código dentro de las etiquetas body menos el menú, De esta forma, la estructura quedaría algo así.

image.png
En el archivo master.blade.php colocaremos una directiva @yield(‘content’), la cual hace referencia al contenido de una sección determinada.

image.png
Optimizar las vistas
En la vista index lo que se hará es quitar todo el código de la parte de la cabecera y el menú, dejando solo la parte interna de la etiqueta body.
Recuerda que en el archivo master.blade.php utilizamos @yield para indicarle que aquí se inyectará contenido de una directiva @section con el nombre content. Por esta razón todo el código del archivo index se encierra con dicha directiva.
Por último, utilizaremos la directiva @extends para indicar que al archivo hereda las propiedades de la vista principal, esté directiva lo vamos a añadir en la cabecera del archivo index especificando el nombre del archivo padre.
image.png
image.png
Alumno
Crear.blade.php
image.png
image.png

editar.blade.php
image.png
image.png
Ver.blade.php
image.png
image.png
Confirmar.blade.php
image.png
image.png
Repetiremos este proceso con todas nuestras vistas de alumnos y curso. Al finalizar, realizamos las pruebas de la aplicación en el navegador.

Componentes y Slots en Blade

Los componentes y slots tienen las mismas funcionalidades que los layouts o secciones. Su aplicabilidad es más sencilla de entender, existen dos enfoques para escribir componentes:
Componentes basados en clases.
Componentes anónimos.

Componentes basados en clases

Realizaremos un ejemplo en nuestra aplicación utilizando componentes basados en clases. Si se observa el código de nuestras vistas, los títulos de las etiquetas h2.
Lo pasaremos a un componente llamado titulo que utilizaremos en todas nuestras vistas, esto con el fin de hacer los títulos más dinámico y variado .
Desde la consola de Artisan creamos el componente:
image.png
Esta línea de código creará dos archivos en nuestra aplicación una es una vista titulo.blade.php en la ruta resources/views/components.
image.png

En segundo lugar, una clase llamado titulo.php ubicada en la ruta app/View/Components
image.png
image.png

Componente de la vista

En el componente de la vista agregamos una etiqueta h2 que recibirá dos variables, una será el nombre del título y otra el color del título.
<h2 style="color: {{ $color }}">{{ $titulo }}</h2>
image.png

Componente en la clase

Seguidamente, abrimos el archivo titulo que se encuentra en la ruta app/View/Components, en el cual se definen dos variables: $titulo y $color, en el constructor aplicamos inyección de dependencias a dichas variables.
Por último, en nuestras vistas reemplazamos la etiqueta del título h2 por el nuevo componente. El componente es declarado con una etiqueta que comienza por x-nombreDelComponente, donde le pasaremos dos parámetros, una es el título y otras es, el color del título.

Avisos
Realizaremos este proceso en todas nuestras vistas. De esta forma, lo que varia en cada vista será el nombre y el color del título.
En la vista index , tenemos una parte del código dedicada a la notificación cuando una acción ha tenido éxito, como borrar un alumno

image.png
vamos a crear el componente Aviso
image.png
Creamos una clase:
image.png
Y desde una vista:
image.png
Para la clase, proporcionamos este código:
image.png
Y para la vista:
image.png
La variable $mensaje recibirá lo que inyectaremos en el componente. Aquí está el código modificado en la vista index :