CursosEmpresasBlogLiveConfPrecios

Función de eliminar

Clase 15 de 20 • Curso de Single Page Applications en Laravel con Inertia y Vue.js

Clase anteriorSiguiente clase

Contenido del curso

Introducción

  • 1
    Cómo aprenderás a crear SPAs en Laravel

    Cómo aprenderás a crear SPAs en Laravel

    02:29 min
  • 2
    Introducción a Jetstream

    Introducción a Jetstream

    03:38 min

Proyecto

  • 3
    Conoce qué SPA vas a construir

    Conoce qué SPA vas a construir

    03:59 min
  • 4
    Configuración inicial

    Configuración inicial

    09:58 min
  • 5
    Sistema basado en componentes

    Sistema basado en componentes

    04:29 min
  • 6
    Jetstream: configuración inicial

    Jetstream: configuración inicial

    09:03 min
  • 7
    Jetstream: personalización

    Jetstream: personalización

    07:42 min
  • 8
    Listado de notas: configuración inicial

    Listado de notas: configuración inicial

    07:38 min
  • 9
    Listado de notas: personalización

    Listado de notas: personalización

    06:12 min
  • 10
    Vista detalle de nota

    Vista detalle de nota

    07:11 min
  • 11
    Formulario de editar

    Formulario de editar

    08:46 min
  • 12
    Código de actualizar

    Código de actualizar

    06:55 min
  • 13
    Formulario de crear

    Formulario de crear

    06:40 min
  • 14
    Código de guardar

    Código de guardar

    04:33 min
  • 15
    Función de eliminar

    Función de eliminar

    Viendo ahora
  • 16
    Flash message

    Flash message

    07:51 min
  • 17
    Buscador

    Buscador

    09:42 min

Conclusión

  • 18
    Repaso final

    Repaso final

    03:31 min
  • 19
    Despedida

    Despedida

    03:21 min
  • 20
    Clase bonus: nunca parar de aprender

    Clase bonus: nunca parar de aprender

    01:33 min
Tomar examen
    Carlos Eduardo Gomez García

    Carlos Eduardo Gomez García

    teacher•
    hace 5 años

    Me gusta inertia porque hace más fácil el hecho de comunicarse con el servidor y tener server side rendering :D . Aun así, me pregunto qué sucede con los hooks de Vue 🤔

      Jose Orlando Parra Soto

      Jose Orlando Parra Soto

      student•
      hace 5 años

      me hago la misma pregunta  😅

      Añaqui Apolinar Morales

      Añaqui Apolinar Morales

      student•
      hace 5 años

      Estaria bueno hacer algun ejercicio con hooks

    Wilmer Omar Aguirre Galdamez

    Wilmer Omar Aguirre Galdamez

    student•
    hace 5 años

    Como trabajo adicional quise agregar un boton de eliminar en el index justo al lado de editar.

    Esto lo logre agregando method="delete" dentro de <inertia-link> y la ruta hacia notes.destroy

      Miguel Bonifaz

      Miguel Bonifaz

      student•
      hace 5 años

      Excelente aporte 👍

      Jaime Andres Ruiz Melendres

      Jaime Andres Ruiz Melendres

      student•
      hace 4 años

      pásale el id de la nota por parámetro a la función destroy,

      @click.prevent="destroy(note.id)

      y lo tomas el método, quedando

      methods:{ destroy($id){ if(confirm('Desea Eliminar?')){ this.$inertia.delete(this.route('notes.destroy',$id)); } } }
    Moisés de Jesús Cortés Castellanos

    Moisés de Jesús Cortés Castellanos

    student•
    hace 3 años

    Yo lo hice en la vista Index, y alado del botón ver y editar puse el botón de eliminar.

    Si a ti te aparece <script setup>, la forma que encontré para que funcionara fue:

    import AppLayout from '@/Layouts/AppLayout.vue'; import { Link, useForm } from '@inertiajs/inertia-vue3'; defineProps({ notes: Array }); const destroy = (id) => { if(confirm('Desea Eliminar?')) { useForm().delete(route('notes.destroy',id)); } }

    Desde luego puedes sacar useForm() en una constante. Y el botón que que hice:

    <button class="bg-blue-500 hover:bg-blue-700 text-white font-bold py-2 px-4 rounded-md" @click.prevent="destroy(note.id) ">Eliminar</button>

    El el controlador del lado del laravel es aplicar el típico delete.

    Nota: A la fecha de esta publicación use Laravel 9.25.1 y Vue 3.2.37.

      Moisés de Jesús Cortés Castellanos

      Moisés de Jesús Cortés Castellanos

      student•
      hace 3 años

      Encontre que podemos sustituir useForm() por Inertia.

      <script setup> import { Inertia } from '@inertiajs/inertia'; import { Link} from '@inertiajs/inertia-vue3'; import AppLayout from '@/Layouts/AppLayout.vue'; defineProps({ notes: Array }); const destroy = id => { if(confirm('Desea Eliminar?')) { Inertia.delete(route('notes.destroy',id)); } } </script>

      Y funciona exactamente igual

    Jimmy Buriticá Londoño

    Jimmy Buriticá Londoño

    student•
    hace 5 años

    Es increíble lo fácil que se hace el CRUD con esta tecnología.

      Abel da Cunha

      Abel da Cunha

      student•
      hace 5 años

      👍

      Cristobal Nyram

      Cristobal Nyram

      student•
      hace 3 años

      y si

    Arnaldo Reyes

    Arnaldo Reyes

    student•
    hace 3 años

    Esta fue el codigo que utilice para que me funcionara Eliminar

    const destroy = () => { if(confirm('Desea Eliminar?')) { form.delete(route('notes.destroy', props.note.id)); } };
      Gustavo Martínez

      Gustavo Martínez

      student•
      hace 3 años

      Muchas gracias por tu aporte!

    Gustavo Eduardo Navarro Rodríguez

    Gustavo Eduardo Navarro Rodríguez

    student•
    hace 4 años

    Se puede hacer de esta forma también después del botón de editar:

    <button @click.prevent="destroy" class="bg-blue-500 hover:bg-blue-700 text-white font-bold py-2 px-4 rounded-md" >Eliminar </button>

    Así queda mejor visualmente y dentro del form. Saludos!.

    Jorge Bou-saad

    Jorge Bou-saad

    student•
    hace 3 años

    Comparto mi commit con Laravel 9

    https://github.com/jlbousing/platzi-inertia/commit/3e2e2ffb1c39d786baca21c8434ed86259750237

    Santiago Velásquez Serna

    Santiago Velásquez Serna

    student•
    hace 2 años

    A marzo de 2024 se usa un router

    import { Link, router } from "@inertiajs/vue3"; .... router.delete("notes/" + id); ...
    Remberto Alvaro Molina Colodro

    Remberto Alvaro Molina Colodro

    student•
    hace 2 años

    Yo lo implemente de esta manera para que me funcionara, lo hice en el Index

    const destroy = ( id ) => { if( confirm('Esta seguro de eliminar esta Nota ?') ) { useForm({}).delete(route('notes.destroy', id)); }

    y mi button

    <button @click.prevent="destroy(note.id)"> Eliminar</button>
    Kenneth Angulo L

    Kenneth Angulo L

    student•
    hace 3 años

    Esta parte fue complicada. Debido al desconocimiento de vue. . Aparantemente hay dos sintaxis diferentes de escribir o de estructurar los archivos vue. . Y por otro lado, encuentro que los botones se comportan diferente dentro o fuera del formulario, eso no me queda claro, Pero con los ultimos comentarios de los companeros encontre como hacerlo. .

    delete note.png

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads