CursosEmpresasBlogLiveConfPrecios

Contenido del curso

DOM y Web API

  • 1
    Y entonces nació internet...

    Y entonces nació internet...

    02:23 min
  • 2
    Accede a la versión más actualizada de este contenido

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

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

    ¿Qué es el DOM?

    02:39 min
  • 4
    Web APIs modernas

    Web APIs modernas

    03:17 min

Operaciones básicas

  • 5
    Leer nodos

    Leer nodos

    09:31 min
  • 6
    NodeLists vs Array

    NodeLists vs Array

    03:46 min
  • 7
    Crear y agregar

    Crear y agregar

    15:47 min
  • 8
    Otras formas de agregar

    Otras formas de agregar

    06:55 min
  • 9
    Atributos y propiedades

    Atributos y propiedades

    05:12 min
  • 10
    Eliminar nodos

    Eliminar nodos

    Viendo ahora
  • 11
    Operaciones en lote

    Operaciones en lote

    06:52 min

Workshop 1: Fetch

  • 12
    Presentación del proyecto

    Presentación del proyecto

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

    Descargando información y creando nodos

    18:36 min
  • 14
    Enriqueciendo la información

    Enriqueciendo la información

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

    Usando la API de internacionalización del browser

    12:14 min
  • 16
    Comparte el resultado

    Comparte el resultado

    02:18 min

Eventos

  • 17
    Reaccionar a lo que sucede en el DOM

    Reaccionar a lo que sucede en el DOM

    13:58 min
  • 18
    Event propagation

    Event propagation

    12:08 min
  • 19
    Event delegation

    Event delegation

    05:32 min

Workshop 2: Lazy loading

  • 20
    Presentación del proyecto

    Presentación del proyecto

    03:34 min
  • 21
    Nuestro propio plugin Lazy Loading

    Nuestro propio plugin Lazy Loading

    08:32 min
  • 22
    Creando las imagenes con JavaScript

    Creando las imagenes con JavaScript

    17:33 min
  • 23
    Intersection Observer

    Intersection Observer

    14:21 min
  • 24
    Aplicando Lazy loading

    Aplicando Lazy loading

    13:07 min
  • 25
    Comparte el resultado

    Comparte el resultado

    03:17 min

Workshop 3

  • 26
    Proyectos propuestos

    Proyectos propuestos

    04:17 min

Librerías relacionadas

  • 27
    ¿Y jQuery?

    ¿Y jQuery?

    03:41 min
  • 28
    ¿Y JSX?

    ¿Y JSX?

    09:40 min

Conclusiones

  • 29
    Conclusiones

    Conclusiones

    01:56 min
Tomar examen

Eliminar nodos

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

      Comentarios

      Fernando Quinteros Gutierrez

      Fernando Quinteros Gutierrez

      Estudiante
      Hace 5 años
        Juan Diego Loaiza Martinez

        Juan Diego Loaiza Martinez

        Estudiante
        Hace 5 años
        Efraín Hernández García

        Efraín Hernández García

        Estudiante
        Hace 5 años
      Carlos Eduardo Gomez García

      Carlos Eduardo Gomez García

      Profesor
      Hace 5 años
        Sergio Sanchez

        Sergio Sanchez

        Estudiante
        Hace 5 años
      Joseph Manuel Salen Pantoja

      Joseph Manuel Salen Pantoja

      Estudiante
      Hace 5 años
        Anfernee Valera

        Anfernee Valera

        Estudiante
        Hace 5 años
        Carlos Escribano Clemente

        Carlos Escribano Clemente

        Estudiante
        Hace 3 años
      Andres Felipe Pinchao Ramirez

      Andres Felipe Pinchao Ramirez

      Estudiante
      Hace 5 años
        Jimmy Buriticá Londoño

        Jimmy Buriticá Londoño

        Estudiante
        Hace 5 años
        Andrés Felipe García Rendón

        Andrés Felipe García Rendón

        Estudiante
        Hace 5 años
      Sebastian Heredia

      Sebastian Heredia

      Estudiante
      Hace 5 años
      Raul Armas

      Raul Armas

      Estudiante
      Hace 5 años
      Asly Nabil Lamas Corrales

      Asly Nabil Lamas Corrales

      Estudiante
      Hace 5 años
        Iris Valentina Barrios

        Iris Valentina Barrios

        Estudiante
        Hace 5 años
        Dario Paladines

        Dario Paladines

        Estudiante
        Hace 4 años
      Juan Gui Arenas

      Juan Gui Arenas

      Estudiante
      Hace 4 años
      Roberto Medina

      Roberto Medina

      Estudiante
      Hace 5 años
      Martín David Roldán

      Martín David Roldán

      Estudiante
      Hace 5 años
        Cristian Blandon

        Cristian Blandon

        Estudiante
        Hace 5 años
        Omar García Betanzos

        Omar García Betanzos

        Estudiante
        Hace 5 años
      santiago GRENAT SANTIAGO

      santiago GRENAT SANTIAGO

      Estudiante
      Hace 4 años
        Edgardo Andres Vargas Saenz

        Edgardo Andres Vargas Saenz

        Estudiante
        Hace 4 años
      Marianna Guedez

      Marianna Guedez

      Estudiante
      Hace 5 años
      Melba Indhira Tejada Leonardo

      Melba Indhira Tejada Leonardo

      Estudiante
      Hace 5 años
      Juan Diego Loaiza Martinez

      Juan Diego Loaiza Martinez

      Estudiante
      Hace 5 años
      Daniel David Mármol Rivero

      Daniel David Mármol Rivero

      Estudiante
      Hace 5 años
      Luis Berenguer

      Luis Berenguer

      Estudiante
      Hace 5 años
      jonathan gonzalez

      jonathan gonzalez

      Estudiante
      Hace 4 años
        Andres Roberto Coello Goyes

        Andres Roberto Coello Goyes

        Estudiante
        Hace 3 años
      Isaac Molina

      Isaac Molina

      Estudiante
      Hace 4 años
        Jonathan 🦑 Alvarez

        Jonathan 🦑 Alvarez

        Profesor
        Hace 4 años
        Josue Granados

        Josue Granados

        Estudiante
        Hace 4 años
      Omar Castillo Ortiz

      Omar Castillo Ortiz

      Estudiante
      Hace 4 años
        Joalin Pineda

        Joalin Pineda

        Estudiante
        Hace 4 años
      Charles Castillo Rosas

      Charles Castillo Rosas

      Estudiante
      Hace 3 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

      Gracias por los resumenes.

      Excelente resumen de estos métodos.

      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)

      Gracias RetaxMaster, excelentes resumenes en este curso.

      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'

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

      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

      /* 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);

      Muy bien explicado, gracias

      Muchas gracias por compartir tus apuntes. Saludos

      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. :)

      También exite parentNode.replaceChildren(), el cual permite reemplazar un array de nodos por otro:

      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?

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

      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")

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

      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 :)

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

      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!

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

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

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

      ELIMINAR NODOS

      DOM_eliminar_nodos.png

      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.

      Hasta el momento, bastante bien el profesor

      _ parentElement.removeChild document.remove document.replaceChild _

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

      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!!

      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.

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

      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 :)

      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í

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

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

      Mis apuntes en Notion💚