CursosEmpresasBlogLiveConfPrecios

Eliminar nodos

Clase 10 de 29 • Curso de Manipulación del DOM

Clase anteriorSiguiente clase

Contenido del curso

DOM y Web API
  • 1
    Y entonces nació internet...

    Y entonces nació internet...

    02:23
  • 2

    Accede a la versión más actualizada de este contenido

    00:14
  • 3
    ¿Qué es el DOM?

    ¿Qué es el DOM?

    02:39
  • 4
    Web APIs modernas

    Web APIs modernas

    03:17
Operaciones básicas
  • 5
    Leer nodos

    Leer nodos

    09:31
  • 6
    NodeLists vs Array

    NodeLists vs Array

    03:46
  • 7
    Crear y agregar

    Crear y agregar

    15:47
  • 8
    Otras formas de agregar

    Otras formas de agregar

    06:55
  • 9
    Atributos y propiedades

    Atributos y propiedades

    05:12
  • 10
    Eliminar nodos

    Eliminar nodos

    09:31
  • 11
    Operaciones en lote

    Operaciones en lote

    06:52
Workshop 1: Fetch
  • 12
    Presentación del proyecto

    Presentación del proyecto

    01:10
  • 13
    Descargando información y creando nodos

    Descargando información y creando nodos

    18:36
  • 14
    Enriqueciendo la información

    Enriqueciendo la información

    10:53
  • 15
    Usando la API de internacionalización del browser

    Usando la API de internacionalización del browser

    12:14
  • 16
    Comparte el resultado

    Comparte el resultado

    02:18
Eventos
  • 17
    Reaccionar a lo que sucede en el DOM

    Reaccionar a lo que sucede en el DOM

    13:58
  • 18
    Event propagation

    Event propagation

    12:08
  • 19
    Event delegation

    Event delegation

    05:32
Workshop 2: Lazy loading
  • 20
    Presentación del proyecto

    Presentación del proyecto

    03:34
  • 21
    Nuestro propio plugin Lazy Loading

    Nuestro propio plugin Lazy Loading

    08:32
  • 22
    Creando las imagenes con JavaScript

    Creando las imagenes con JavaScript

    17:33
  • 23
    Intersection Observer

    Intersection Observer

    14:21
  • 24
    Aplicando Lazy loading

    Aplicando Lazy loading

    13:07
  • 25
    Comparte el resultado

    Comparte el resultado

    03:17
Workshop 3
  • 26
    Proyectos propuestos

    Proyectos propuestos

    04:17
Librerías relacionadas
  • 27
    ¿Y jQuery?

    ¿Y jQuery?

    03:41
  • 28
    ¿Y JSX?

    ¿Y JSX?

    09:40
Conclusiones
  • 29
    Conclusiones

    Conclusiones

    01:56
    Fernando Quinteros Gutierrez

    Fernando Quinteros Gutierrez

    student•
    hace 5 años

    🙅 Eliminar Nodos

    Apuntes

    • Existen 3 formas de eliminar nodos en el DOM
    1. Remove Child

      • Podemos eliminar un nodo según a un método que proviene del padre y pasamos la referencia a eliminar
      padre.removeChild(nodoAEliminar)
    2. Remove

      • Es la evolución de remove child
      • No esta soportado en internet explorer
      nodoAEliminar.remove()
    3. Replace Child

      • Nos permite remplazar un nodo
      padre.replaceChild(nuevoNodo, aRemplazar)

    RESUMEN: Podemos eliminar nodos con diferentes métodos que nos provee el DOM como ser removeChild, el cual necesita la referencia del padre a eliminar y del nodo que se eliminara, remove el cual se encarga de eliminar el nodo solo con la referencia deseada a borrar y finalmente replaceChild que nos ayuda remplazar un elemento con las referencias del padre, el nuevo nodo y el elemento a remplazar

      Juan Diego Loaiza Martinez

      Juan Diego Loaiza Martinez

      student•
      hace 5 años

      Gracias por los resumenes.

      Efraín Hernández García

      Efraín Hernández García

      student•
      hace 5 años

      Excelente resumen de estos métodos.

    Carlos Eduardo Gomez García

    Carlos Eduardo Gomez García

    teacher•
    hace 5 años

    También debemos aprender a eliminar nodos dentro del HTML, si podemos agregarlos... ¿Por qué no podríamos eliminarlos? ¡Claro que se puede!, y para ello, JavaScript nos ofrece 3 formas: .

    • parentElement.removeChild(): Elimina un elemento hijo a partir del elemento padre:
    // Nota: En la clase se hizo con $0, pero yo te lo dejo en cómo lo harías normalmente con JavaScript // Selecciono el elemento que quiero eliminar const nodoAEliminar = document.querySelector("selector") // Selecciono a su padre directo const parentElement = nodoAEliminar.parentElement // Lo elimino parentElement.removeChild(nodoAEliminar)
    • docuement.remove(): Es la evolución de removeChild Y... tampoco es soportado por Internet Explorer ¬¬! . No importa, aquí está el polyfill:D https://developer.mozilla.org/es/docs/Web/API/ChildNode/remove#polyfill
    // Selecciono el elemento que quiero eliminar const nodoAEliminar = document.querySelector("selector") // Lo elimino uwu nodoAEliminar.remove()
    • document.replaceChild(): Reemplaza un nodo (en pocas palabras lo elimina y mete otro)
    // Selecciono un padre const padre = document.querySelector("selector") // Selecciono el elemento al que voy a reemplazar const toReplace = document.querySelector("selector") // Creo el nodo por el cual lo voy a reemplazar const node = document.createElement("h1") // Le pongo un texto node.textContent = "Un texto cualquiera" // Lo reemplazo >:D!!! parent.replaceChild(node, toReplace)
      Sergio Sanchez

      Sergio Sanchez

      student•
      hace 4 años

      Gracias RetaxMaster, excelentes resumenes en este curso.

    Joseph Manuel Salen Pantoja

    Joseph Manuel Salen Pantoja

    student•
    hace 5 años

    También hay otro método de reemplazar nodos que es node.replaceWith :D . node.replaceWith: También nos sirve para reemplazar un nodo, pero de una manera más cómoda ya que no necesitamos pasar dos argumentos sino solo uno -> el nuevo nodo, lo que hace que sea incluso más fácil de leer: .

    const nodoACambiar = document.querySelector('h2') const nodoNuevo = document.createElement('h1') nodoNuevo.textContent = "Nuevo Nodo" nodoACambiar.replaceWith(nodoNuevo) Antiguo DOM: div |_h2 'Old text' Nuevo DOM: div |_h1 'Nuevo Nodo'
      Anfernee Valera

      Anfernee Valera

      student•
      hace 4 años

      Está muy bueno y sencillo de usar :D, Gracias por el aporte.

      Carlos Escribano Clemente

      Carlos Escribano Clemente

      student•
      hace 3 años

      Si, así lo hice yo también porque me lo sugirió la consola, el tema, como se comenta otras veces, es conocer el soporte en los distintos navegadores y versiones

    Andres Felipe Pinchao Ramirez

    Andres Felipe Pinchao Ramirez

    student•
    hace 5 años
    /* Eliminar Nodos Asi como podemos crear, agregarlos y modificar tambien podremos eliminar nuestros nodos. -> parentElement.removeChild -> document.remove -> document.replaceChild //remplazar nodo */ // Selecciono el elemento que quiero eliminar const nodoAEliminar = document.querySelector("id") // Selecciono al padre directo const padre = document.querySelector("class") /* Eliminamos el elemento pasandole por parametro lo que queremos eliminar al metodo removeChild() */ padre.removeChild(nodoAEliminar) /* Tambien podremos eliminarlo de otro forma con la propiedad parentElement que hace referencia al padre del elemento que queremos eliminar */ const padre2 = nodoAEliminar.parentElement; padre2.removeChild(nodoAEliminar); /* node.remove ->Es la evolución de removeChild -> No soportado IE Remove no nos pedira ningun padre ni tampoco ninguna referencia Solo necesitamos seleccionar el elemento que queremos eliminar y utilizar el metodo .remove() y se eliminara */ const elementoEliminar = document.querySelector("div"); elementoEliminar.remove(); /* node.replaceChild para utilizar replace child necesitamos el padre el elemento a remplazar y el elemento de referencia */ //seleccionamos el elemento padre const elementoPadre = document.querySelector('idContenedor'); //selecionamos la referencia del elemento que queremos remplazar const elementoRemplazo = document.querySelector('idQuevamosARemplazar'); //creamos el elemento nuevo por el cual vamos a remplazar al otro const elementoNuevo = document.createElement('h1'); //agregamos texto al elemento nuevo elementoNuevo.textContent = "Form Checkout"; /* Utilizamos el metodo .replaceChild que recibe por parametro el elemento nuevo y el segundo el elemento por el cual lo vamos a remplazar*/ elementoPadre.replaceChild(elementoNuevo,elementoRemplazo);
      Jimmy Buriticá Londoño

      Jimmy Buriticá Londoño

      student•
      hace 5 años

      Muy bien explicado, gracias

      Andrés Felipe García Rendón

      Andrés Felipe García Rendón

      student•
      hace 5 años

      Muchas gracias por compartir tus apuntes. Saludos

    Sebastian Heredia

    Sebastian Heredia

    student•
    hace 4 años

    Pienso que para eliminar un nodo por mas grande que sea el proyecto usar un "removeChild" es algo innecesario puesto que simplemente podemos seleccionar con $0 el nodo y gulag. . Las nuevas implementaciones de remove y de append sin ninguna propiedad es demasiado útil. :)

    Raul Armas

    Raul Armas

    student•
    hace 5 años

    También exite parentNode.replaceChildren(), el cual permite reemplazar un array de nodos por otro: https://developer.mozilla.org/en-US/docs/Web/API/ParentNode/replaceChildren

    Asly Nabil Lamas Corrales

    Asly Nabil Lamas Corrales

    student•
    hace 4 años

    Cómo se haría para cambiarle una propiedad de una etiqueta, por ejemplo cambiarle una clase por otra, o el nombre del id, O por ejemplo cómo se haría para cambiar el tamaño a una imagen o algún estilo de esta?

      Iris Valentina Barrios

      Iris Valentina Barrios

      student•
      hace 4 años

      ¡Hola Platzinauta 🖐! Si deseas agregar, eliminar o desactivar una Clase de tu Elemento, puedes usar Element.classList Para agregar, eliminar o editar estilos puedes usar Element.style Puedes ver la documentación en los links que te dejé antes :D

      Dario Paladines

      Dario Paladines

      student•
      hace 3 años

      Para los nuevos, y supongo que lo hablarán mas adelante en alguna clase pero, para agregar o quitar clases es simplemente:

      • nodo.classList.add("nuevo nombre de la clase")

      • nodo.classList.remove("nombre de la clase a eliminar")

      Y para los estilos igualmente:

      • nodo.style.backgroundImage = ("valores correspondientes")
    Juan Gui Arenas

    Juan Gui Arenas

    student•
    hace 4 años

    :O Aww este curso me esta sirviendo mucho, cada clase se aprende mucho y el profersor explica muy bien :)

    Roberto Medina

    Roberto Medina

    student•
    hace 5 años

    Hola:

    En el minuto 9:06, no se ven las diapositivas para mostrar de forma gráfica el funcionamiento del replaceChild()

    Antes de replaceChild:

    Después de replaceChild:

    Saludos :)

    Martín David Roldán

    Martín David Roldán

    student•
    hace 5 años

    Hola :D Internet Explorer casi ya no se usa. ¿Se necesita darle soporte?

      Cristian Blandón

      Cristian Blandón

      student•
      hace 5 años

      Depende de tu usuario... Si vas a desarrollar aplicaciones de propósito general para cualquier usuario "particular", te diría que no es necesario.

      En cambio, si vas a desarrollar una web app para una empresa en la que sólo usan Internet Explorer por política de sus headquarters y eso es inamovible, bueno, tendrías que darle soporte a IE.

      ¡Saludos!

      Omar García Betanzos

      Omar García Betanzos

      student•
      hace 5 años

      Habrá empresas que lo pidan pero el esfuerzo no compensa, tenemos que convencer de ello a las empresas.

    santiago GRENAT SANTIAGO

    santiago GRENAT SANTIAGO

    student•
    hace 4 años

    cada vez que quiero eliminar un elemento necesito primero guardarlo en una const? , o puedo usar $0 y el .remove?

      Edgardo Andres Vargas Saenz

      Edgardo Andres Vargas Saenz

      student•
      hace 4 años

      Hola santi_g2000, no es necesario guardarlo en una constante, tú puedes seleccionar la etiqueta e inmediatamente agregarle .remove

    Marianna Guedez

    Marianna Guedez

    student•
    hace 4 años

    ELIMINAR NODOS

    DOM_eliminar_nodos.png

    Melba Indhira Tejada Leonardo

    Melba Indhira Tejada Leonardo

    student•
    hace 5 años

    La función removeChild() requiere como parámetro el nodo que se va a eliminar. Además, esta función debe ser invocada desde el elemento padre de ese nodo que se quiere eliminar. La forma más segura y rápida de acceder al nodo padre de un elemento es mediante la propiedad nodoHijo.

    Juan Diego Loaiza Martinez

    Juan Diego Loaiza Martinez

    student•
    hace 5 años

    Hasta el momento, bastante bien el profesor

    Daniel David Mármol Rivero

    Daniel David Mármol Rivero

    student•
    hace 5 años

    _ parentElement.removeChild document.remove document.replaceChild _

    Luis Berenguer

    Luis Berenguer

    student•
    hace 4 años

    El método remove( ) parece más útil que removeChild( ) a primera vista.

    jonathan gonzalez

    jonathan gonzalez

    student•
    hace 3 años

    Hola profes tengo una pregunta, que es mejor usar cuando estyo haciendo un web para ocultar secciones los métodos que vimos como remove() o usar los display: none de CSS.

    Es que normalmente cuando hago una landing oculto las vistas con display: none; pero ahora viendo esta clase veo que se pueden remover y me genera la duda de cual es mejor

    Gracias y saludos!!

      Andres Roberto Coello Goyes

      Andres Roberto Coello Goyes

      student•
      hace 3 años

      Puedes usar un "Loading de fondo" como lo muestra esta libreria: https://v4.mui.com/components/backdrop/

      Donde se muestra el loading y el resto no se podra manipular hasta que desaparezca el loading.

    Isaac Everaldo Molina Ponce

    Isaac Everaldo Molina Ponce

    student•
    hace 4 años

    ¿Por que se usa la propiedad ".textContent" y no la de "innerHTML" ?

      Jonathan 🦑 Alvarez

      Jonathan 🦑 Alvarez

      teacher•
      hace 4 años

      Hola Isaac, es una pregunta buenísima y super importante porque tiene que ver con seguridad – y muy seria. En clases posteriores me adentro en ello :)

      Josue Granados

      Josue Granados

      student•
      hace 4 años

      Existen muchas formas de modificar/agregar/sobreescribir el texto de un elemento HTML. Para responder a tu pregunta textContent literalmente modifica/regresa el texto dentro de un elemento HTML sin formato alguno (estilo, saltos de linea, tabs, etc). . Hay una propiedad similar llamada innerText que representa el texto dentro de un elemento con todo y formato (estilo, salto de linea, etc). . Las diferencias entre innerHTML, innerText y textContent son muy interesantes :) . Te dejo un link donde puedes leer más aquí

    Omar Castillo Ortiz

    Omar Castillo Ortiz

    student•
    hace 4 años

    las diapositivas no esta para descargar alguien sabe donde la encuntro?

      Joalin Pineda

      Joalin Pineda

      student•
      hace 4 años

      ¡Hola! Casi en todos los cursos las puedes encontrar en la primera clase, también te las comparto por acá.

    Charles Duck Castillo Rosas

    Charles Duck Castillo Rosas

    student•
    hace 3 años

    Mis apuntes en Notion💚

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