CursosEmpresasBlogLiveConfPrecios

Reaccionar a lo que sucede en el DOM

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

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

    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

    09:31 min
  • 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

    Viendo ahora
  • 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

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
      Carlos Eduardo Gomez García

      Carlos Eduardo Gomez García

      teacher•
      hace 5 años
        Santiago Lopera Naranjo

        Santiago Lopera Naranjo

        student•
        hace 5 años
        Jonathan 🦑 Alvarez

        Jonathan 🦑 Alvarez

        teacher•
        hace 5 años
      Luis Berenguer

      Luis Berenguer

      student•
      hace 4 años
        Carlos Sanjuan

        Carlos Sanjuan

        student•
        hace 4 años
      Axel Yaguana

      Axel Yaguana

      Team Platzi•
      hace 5 años
      Fernando Quinteros Gutierrez

      Fernando Quinteros Gutierrez

      student•
      hace 5 años
        Edgar Lopez Arroyo

        Edgar Lopez Arroyo

        student•
        hace 5 años
      Jimmy Buriticá Londoño

      Jimmy Buriticá Londoño

      student•
      hace 5 años
      Luciano Marchese

      Luciano Marchese

      student•
      hace 5 años
      Melba Indhira Tejada Leonardo

      Melba Indhira Tejada Leonardo

      student•
      hace 5 años
      Joel Eduardo Sánchez Herrera

      Joel Eduardo Sánchez Herrera

      student•
      hace 5 años
      Sebastian Heredia

      Sebastian Heredia

      student•
      hace 5 años
      Andrés D Amelio

      Andrés D Amelio

      student•
      hace 5 años
      Felipe Zapata

      Felipe Zapata

      student•
      hace 4 años
        Edgardo Andres Vargas Saenz

        Edgardo Andres Vargas Saenz

        student•
        hace 4 años
      Efraín Hernández García

      Efraín Hernández García

      student•
      hace 5 años
      Melba Indhira Tejada Leonardo

      Melba Indhira Tejada Leonardo

      student•
      hace 5 años
        Daniel Adolfo Ordoñez Rubio

        Daniel Adolfo Ordoñez Rubio

        student•
        hace 5 años
        Melba Indhira Tejada Leonardo

        Melba Indhira Tejada Leonardo

        student•
        hace 5 años
      Estefania Mazo Uribe

      Estefania Mazo Uribe

      student•
      hace 4 años
      Edgar Lopez Arroyo

      Edgar Lopez Arroyo

      student•
      hace 5 años
      Andrea Lozano Cataño

      Andrea Lozano Cataño

      student•
      hace 5 años
        Alondra Peña

        Alondra Peña

        student•
        hace 5 años
      Carlos Rodríguez

      Carlos Rodríguez

      student•
      hace 4 años
      Daniel David Mármol Rivero

      Daniel David Mármol Rivero

      student•
      hace 5 años
      Nelson Gonzalez Escalante

      Nelson Gonzalez Escalante

      student•
      hace 4 años
      Andres Felipe Pinchao Ramirez

      Andres Felipe Pinchao Ramirez

      student•
      hace 5 años
        fermin martin

        fermin martin

        student•
        hace 5 años

      Aquí pueden encontrar una lista con todos los eventos disponibles en JavaScript y a qué API pertenece :D . La función addEventListener() nos permite añadir eventos a nuestros elementos, la podemos usar de la siguiente manera:

      miElemento.addEventListener("evento", manejador)

      En este caso, el manejador debe ser una función callback que se ejecutará cuando el evento sea disparado. Es muy común verlo como una función anónima:

      button.addEventListener("click", () => { alert("Me has clickado 😄") })

      Sin embargo, la mejor práctica es crear funciones por separado, así siempre tendremos una referencia a dicha función (con una función anónima no tenemos nada que la identifique, de ahí su nombre)

      const miFuncionManejadora = () => { alert("Me has clickado 😄") }; button.addEventListener("click", miFuncionManejadora) // Presta atención como la estamos mandando sin paréntesis, porque de esa forma solo le pasamos la referencia de la función, si le pusieramos paréntesis entonces la estaríamos ejecutando

      Y esto tiene la ventaja de que podemos remover los eventos cuando queramos ya que tenemos la referencia de la función manejadora :D

      const miFuncionManejadora = () => { alert("Me has clickado 😄") }; // Agrego el evento button.addEventListener("click", miFuncionManejadora) // Quito el evento button.removeEventListener("click", miFuncionManejadora)

      También podemos definir funciones de esta otra manera 👀

      button.onClick = () => { alert("Me has clickado 😄") }

      Esta sintaxis es onEvento pero no es muy común ^^ . Como dato adicional, esta es otra forma de añadir eventos desde HTML: . HTML

      <button onclick="miFuncionManejadora">Clicame</button>

      JavaScript

      const miFuncionManejadora = () => { alert("Me has clickado 😄") };

      De esta forma, el botón, mediante un atributo estaría llamando a la función :D

      Buen aporte!, Soy bastante fan de usar el onEvent desde JavaScript me parece que se ve mas amigable a diferencia del addEventListener()

      "onEvent" generalmente no es buena idea porque solo puedes definirlo una vez.

      addEventListener te deja agregar listeners de forma ilimitada.

      A este profesor se le puede poner a x2.5😂

      Pense que era el unico que lo hacia jaja. Es tan genialmente elocuente que al aumentale la velocidad de reproduccion aun se le entiende lo que hace y lo que dice de ina forma maravillosa.

      El segundo argumento de un eventListener es una función. Si se dan cuenta no se le pone el paréntesis () porque solo necesitamos hacer referencia a ella, no ejecutarla. Al momento de suceder el evento es cuando la función se ejecuta.

      🌟 Reaccionar a lo que sucede en el DOM

      Ideas / conceptos claves

      Una función anónima es una definición de función que no está vinculada a un identificador

      Apuntes

      • JS es un lenguaje que está basado en eventos

      ✨ Toda la magia sucede cuando escuchamos los eventos y reaccionamos con lo que sucede

      Eventos

      Add Event Listener

      • Agrega un evento
      node.addEventListener(tipoDeEvento, callback)
      • Todos los eventos envían información del evento como un parámetro al callback
        • Existen eventos específicos para elementos HTML especiales como ser video o audio

      Remove Event Listener

      • Elimina un evento
      • Debemos especificar el tipo de evento y la referencia de la función al momento de invocar el método del elemento HTML
      • Es recomendable si deseamos eliminar eventos a futuro no crear funciones anónimas por que se perderá la referencia
      node.removeEventListener(tipoDeEvento, callback)

      RESUMEN: Todos los elementos del DOM pueden tener las propiedades para agregar o eliminar eventos según diferentes acciones. Algunos elementos tienen acciones específicas como ser los videos o audios

      Gran resumen!! 👍

      Me ha gustado mucho el curso, Jonathan explica muy bien.

      Aunque no remueve el listener de funciones anonimas, aca hay un truquito para ejecutar el listener una sola vez:

      button.addEventListener( 'click', () => { alert( 'presionado' ); }, { once: true } );

      Importante: un evento tiene que tener una acción, con su nombre, para poder eliminarla.

      JS es un lenguaje que esta basado en eventos, la magia ocurre cuando los escuchamos y es aqui donde ocurre lo interesante en las apliaciones. Para escuchar eventos usamos:

      • node.addEventListener → Para escuchar eventos
      • node.removeEventListener →Para eliminar los eventos que hemos agregado

      Los arguemntos de AddEventListener tenemos 3 argumentos que mandar que es:

      1. Tipo: Existen varios, el mas popular es el 'click' de cuando hacemos click, al igual existe el 'input' es saber cuando ingresaron datos en el input.
      2. Listener, que quiero hacer cada vez que haya un click o la accion

      Todos los eventos que hacemos nos retornan un valor con toda la inforamcion que pueda tener ese evento. Como por ejemplo el valor event.data que es lo que el usuario haya podido escribir en un input

      Si utilizamos funciones inline como no tienen nombre, nunca podriamos eliminarlas.

      Genial, entonces como buena practica siempre debemos ponerle un nombre a nuestro evento o no lo podremos eliminar después. :)

      Eventos

      En javascript podemos trabajar con programación orienta a eventos, es decir, podemos ejecutar instrucciones de código de acuerdo a un evento en particular, ya sea que se haya pulsado un botón, presionando un check, escrito en un input, etc.

      Cada evento dispone de un controlador de eventos, que no es más que un bloque de código (generalmente una función) que se ejecutará cuando se active el evento. Cuando asociamos cada bloque de código a un evento estamos registrando un controlador de evento u oyente de eventos. Este oyente esta pendiente si ocurre un evento, y el controlador es el código que se ejecuta en respuesta a dicha acción.

      Existe diversas formas de manejar eventos en Javascript, pero la más conocida y recomendada son addEventListener y removeEventListener, veamos un poco mas sobre estos

      • addEventListener: Nos permite registrar un evento a un nodo especifico de nuestro DOM. Podemos usarla varias veces sobre un mismo elemento, para esto solo debemos invocarla tantas veces queramos y definimos los eventos que queremos escuchar. Veamos su sintaxis,

        element.addEventListener(tipo, listener);

        Estos parámetros tienen las siguientes funciones,

        • tipo: Este parámetro es de tipo string, y representa el tipo de evento a escuchar, toma diversos valores, según el elemento al que se le esta registrando el evento, los mas conocidos y usados son: click, change (inputs, textarea, select), input, keydown, keyup, load, etc.
        • listener: El objeto que recibe una alerta cuando el evento ocurre. puede una función directa, o el llamado de una función ya declarada. Si se usa una función ya declarada es importante señalar que no se le deben de colocar los paréntesis () porque en ese punto se esta haciendo referencia a la función que se ejecutará en caso de que ocurra el evento. Si se colocan los paréntesis, en lo que se este registrando el evento esta se invocará inmediatamente y no es lo que se quiere.

        Ahora veamos un pequeño ejemplo, donde se le agregará el evento click a un botón, y ejecutará un función.

        let button = document.querySelector(".btn"); // Primera forma (Función declarada) const showAlert = () => { alert("Alerta, esto es una emergencia"); }; button.addEventListener("click", showAlert); // Segunda forma (Función en linea) button.addEventListener("click", function() { alert("Alerta, esto es una emergencia"); });
      • removeEventListener: Este método nos permite remover un evento del elemento que lo invoca, por lo que a partir de ese momento ese evento dejará de existir para el elemento. recibe varios parámetros de igual forma que el método anterior, el primero de ellos es el tipo de evento que vamos a eliminar, el mismo que indicamos cuando lo registramos con el addEventListener, en segundo lugar debemos enviar el listener asociado al evento, y esto es debido a que podemos registrar el mismo evento varias veces y ejecutar códigos diferentes, por lo que debemos especificar cual en particular vamos a eliminar. Una cosa a tomar en cuenta debemos de tratar en lo posible de agregar eventos y ejecutar funciones ya definidas, porque debemos hacer referencia a estas al momento de remover el evento, y si las agregamos en linea no tenemos una referencia sobre esa función porque es una función anónima. Veamos un ejemplo de como usar este método.

        let button = document.querySelector(".btn"); const showAlert = () => alert("Alerta, esto es una emergencia"); // Agregamos el evento button.addEventListener("click", showAlert); // Eliminamos el evento button.removeEventListener("click", showAlert);

      Como vemos, al eliminar el evento hicimos referencia a la función showAlert. Si hubiésemos declarado la función directamente no tendríamos forma de hacer referencia.

      como hago para saltar de renglon en la consola de chrome?

      Hola fzapataramirez, si estas en Windows puedes usar Shift + Enter

      Por fin! una clase que explica de manera muy detallada la parte de los eventos. Excelente clase!

      const input = document.getElementById('FirstName') input <input type="text" class="form-control" id="firstName" placeholder value required>_</input> const accion = () => { console.log('Ha sucedido un click') } input.addEventListener('click', accion) console.log('Ha sucedido un click') VM7349:1 Ha sucedido un click

      :) Siempre es bueno revisar nuestro código y ver que coincidan los nombres :eyes:, por ejemplo en document.getElementById('FirstName') tienes el nombre iniciando con mayúscula, pero en tu <input> tienes id firstName iniciando en minúscula :D.

      Gracias.

      Jonathan explica excelente!!!

      Métodos para agregar y eliminar un evento a un elemento:

      Agregar:

      element.addEventListener('evento', función que se ejecuta cuando se detecta el evento)

      deshabilitar:

      element.removeEventListener('evento', función que se ejecuta cuando se detecta el evento)

      ¿Qué significa y para qué sirve event y target?

      Tal vez te sirva esto: https://www.youtube.com/watch?v=GBez9_xzRL8&t=349s&ab_channel=Granosdecaf%C3%A9

      // Seleccionar nodo const input = document.querySelector('#firstName'); // Acción al capturar evento const action = () => { console.log('Ha sucedido un click'); }; // Detectar evento click input.addEventListener('click', action); // Detectar cambio en un input input.addEventListener('input', (event) => { // event: argumento por defecto que nos da información de lso eventos console.log(`Hey!: ${event}`); }); // Imprimir el taget al hacer click input.addEventListener('click', (event) => { console.log(event.target); }); // Otra forma de imprimir el taget al hacer click input.addEventListener('click', function () { console.log(this.target); // El this dentro de este scope captura las informaciones de event // sin embargo el this no es compatible con arrow functions // por eso en arrow function se usa el argumento (event) }); // Seleccionar nodo const email = document.querySelector('#email'); const action1 = () => console.log('Acción 1'); const action2 = () => console.log('Acción 2'); // Detectar evento click email.addEventListener('click', action1); email.addEventListener('click', action2); // Eliminar evento, debemos siempre colcoar la acción en una función aparte para que en un futuro podamos eliminarla email.removeEventListener('click' ,action1);
      // Agregar eventos a los nodos. const input = document.getElementById('firstName'); const accion = () => { console.log('ha sucedido un click'); }; input.addEventListener('click', accion) // Primer argumento es la accion que escucho y el segundo que quiero hacer al escucharlo, es decir, una funcion directamente, con sintaxis flecha o definir una variable con funcion. // Otro evento que funciona es input input.addEventListener('input', () => { console.log('heey!'); }); //Cada vez que escriba en un input // se me daran los dos // Puedo analizar las propiedades del evento. input.addEventListener('input', (event) => { if (event.data === 'p') { console.log('escribiste una p'); } }); // Los eventos que nosotros agreguemos a un nodo tienen tanto semtido como el nodo al que estamos eacuchando. // Eliminar event const email = document.getElementById('email'); const accion1 = () => console.log('accion 1'); const accion2 = () => console.log('accion 2'); email.addEventListener ('click', accion1) email.addEventListener ('click', accion2) email.removeEventListener('click', accion1) // Esto es una de las razones por las que usar funciones inline o funciones anonimas no permiten ser eliminadas como eventos porque no tienen nombre.

      Los eventos se envían para notificar al código de cosas interesantes que han ocurrido. Cada evento está representado por un objeto que se basa en la interfaz Event, y puede tener campos o funciones personalizadas adicionales para obtener más información acerca de lo sucedido. Los eventos pueden representar cualquier cosa desde las interacciones básicas del usuario para notificaciones automatizadas de las cosas que suceden en el modelo de representación.

      Apuntes Sobre Los Eventos 👂👂

      /* Eventos -> node.addEventListener -> node.removeEventListener */ //seleccionamos el elemento con el cual vamos a utilizar los eventos const input = document.querySelector('firstName'); /* agregamos al input ek escuchador de eventos .addEventListener() este metodo recibe como 1 parametro que tipo de evento vamos a escuchar En el segundo parametro de esta funcion tengo que especificar un listener es decir que quiero hacer cuando haya un click agregamos una function puede ser una arrow fuction funcion anonima agregar una funcion ahi mismo */ const accion = () =>{ console.log('ha sucedio un click') } input.addEventListener('click', accion) // tipo de evento input si escribo en el input dispara el evento input.addEventListener('input', () =>{ console.log('hey') }) /* Todos los eventos en nuestra funcion nos va a enviar un parametro que se llama evento a este parametro no importa el nombre que le asignemos Pero este evento nos trae mucha informacion a la que podremos acceder en conjunto con el punto */ input.addEventListener('input', (event) =>{ console.log(event) /* Data recibe lo que se digita en el input entonces cuando digitemos p se ejecutara el evento y imprimira algo en consola*/ if(event.data === 'p'){ console.log('Escribiste una "p"'); } }) /* Ahora veremos como eliminar los eventos que hemos agregado para que no se acumulen y los podamos controlar atraves de removeAddListener */ const email = document.querySelector('email'); // Creamos la funcion que utilizaremos en nuestro escuchador de eventos const accionUno = () => console.log('accion 1'); const accionDos = () => console.log('accion 2') /* Podremos agregar mas de dos eventos a un solo elemento y se ejecutaran en orden */ email.addEventListener('click', accionUno); email.addEventListener('click', accionDos); /* Para eliminar una accion utilizamos la funcion .removeEventListener() que recibe por parametro el evento y la accion que vamos a eliminar que en este caso es la funcion anonima. */ email.removeEventListener('click', accionUno); /* Por eso es recomendable no utilizar funciones anonimas ya que si las quisieramos eliminar no se podria eliminar */ email.addEventListener('click', () => {console.log('algo')}) email.removeEventListener() /* si utilizaramos esta funcion no podriamos eliminar porque seria una funcion sin nombre entonces no tendriamos un argumento que pasar como 2 parametro*/

      Me gustan las dos orejas 👂👂 ... thanks for sharing