CursosEmpresasBlogLiveConfPrecios

Creación de salas con Socket.io

Clase 12 de 26 • Curso de Aplicaciones en Tiempo Real con Socket.io

Clase anteriorSiguiente clase

Contenido del curso

Fundamentos de Socket.io

  • 1
    Cómo hacer aplicaciones en tiempo real

    Cómo hacer aplicaciones en tiempo real

    08:19 min
  • 2
    Protocolos de comunicación: HTTP vs. WebSockets

    Protocolos de comunicación: HTTP vs. WebSockets

    07:49 min
  • 3
    ¿Qué es Socket.io?

    ¿Qué es Socket.io?

    03:48 min
  • 4
    Socket.io vs. WebSockets

    Socket.io vs. WebSockets

    06:00 min
  • 5
    ¿Cómo funciona Socket.io?

    ¿Cómo funciona Socket.io?

    10:49 min
  • 6
    Ciclo de vida de Socket.io

    Ciclo de vida de Socket.io

    06:17 min

Socket.io en la práctica

  • 7
    Creando nuestra primera aplicación con Socket.io

    Creando nuestra primera aplicación con Socket.io

    18:09 min
  • 8
    Obteniendo información de conexiones en el servidor

    Obteniendo información de conexiones en el servidor

    18:18 min
  • 9
    Emisión de eventos

    Emisión de eventos

    13:42 min
  • 10
    On, Once y Off

    On, Once y Off

    16:41 min
  • 11
    Broadcast de eventos

    Broadcast de eventos

    21:19 min
  • 12
    Creación de salas con Socket.io

    Creación de salas con Socket.io

    Viendo ahora
  • 13
    Namespaces en Socket.io

    Namespaces en Socket.io

    15:54 min
  • 14
    Lógica de envio de mensajes

    Lógica de envio de mensajes

    12:20 min
  • 15
    Manejo offline

    Manejo offline

    09:49 min
  • 16
    Eventos volátiles

    Eventos volátiles

    07:19 min
  • 17
    Manejo de Middlewares

    Manejo de Middlewares

    12:54 min

Herramientas extra

  • 18
    Debugging en Socket.io

    Debugging en Socket.io

    11:16 min
  • 19
    Configuración para testing usando la librería jest

    Configuración para testing usando la librería jest

    16:00 min
  • 20
    Testing con jest

    Testing con jest

    10:33 min
  • 21
    Admin UI

    Admin UI

    13:40 min

Proyecto WebChat

  • 22
    Estructura inicial del proyecto WebChat

    Estructura inicial del proyecto WebChat

    19:25 min
  • 23
    Sistema de autenticación

    Sistema de autenticación

    17:38 min
  • 24
    Programando la lógica del chat

    Programando la lógica del chat

    15:38 min
  • 25
    Detalles finales y demostración de chat en tiempo real

    Detalles finales y demostración de chat en tiempo real

    07:55 min

Cierre

  • 26
    ¿Quieres un Curso Práctico de Socket.io?

    ¿Quieres un Curso Práctico de Socket.io?

    01:58 min
  • Tomar el examen del curso
    • Carlos Alejandro Hernández Mejía

      Carlos Alejandro Hernández Mejía

      student•
      hace 3 años

      Creación de salas

      Hasta el momento, hemos visto cómo mandar eventos. Desde la emisión básica uno a uno, hasta la emisión a todos los sockets conectados por medio de broadcast, e incluso, hasta el envío de eventos a un socket en particular.

      Pero también, se pueden agrupar sockets por medio de salas y enviarles eventos solo aquellos que pertenezcan a una sala en particular.

      💡 Por ejemplo, esto se podría usar en un chat grupal, donde solo recibirán los mensaje los miembros que pertenezcan a dicho grupo.

      Así implementé esta clase para que el código fuera más dinámico:

      • src/index.js:
      io.on('connection', (socket) => { socket.connectedRoom = null; socket.on('connectToRoom', (room) => { if (socket.connectedRoom) { socket.leave(socket.connectedRoom); } socket.connectedRoom = room; socket.join(room); }); socket.on('message', (message) => { const room = socket.connectedRoom; if (room) { io.to(room).emit('newMessage', { message, room, sender: socket.id, }); } }); });
      • index.html
      <body> <ul class="room" id="room1"> </ul> <ul class="room" id="room2"> </ul> <ul class="room" id="room3"> </ul> <form> <label for="connect-room"> Connect to room: <input min="1" max="3" step="1" type="number" id="connect-room" placeholder="Enter your room number"> </label> <button type="button" onclick="connectTo()"> Connect </button> </form> <form> <label for="message"> Message: <input type="text" id="message" placeholder="Enter your message"> </label> <button type="button" onclick="sendMessage()"> Send </button> </form> <script src="/socket.io/socket.io.js"></script> <script src="/js/index.js"></script> </body>
      • js/index.js
      const socket = io(); function connectTo() { const connectRoom = document.getElementById('connect-room'); const connectRoomValue = connectRoom.value; if (connectRoomValue) { socket.emit('connectToRoom', `room${connectRoomValue}`); } } function sendMessage() { const message = document.getElementById('message'); const messageValue = message.value; if (messageValue) { socket.emit('message', messageValue); message.value = ''; } } function receiveMessage({ room, sender, message }) { const roomElement = document.getElementById(room); const messageElement = document.createElement('li'); messageElement.textContent = `${sender}: ${message}`; roomElement.appendChild(messageElement); } socket.on('newMessage', receiveMessage);
        Nicolás Arévalo

        Nicolás Arévalo

        student•
        hace 3 años

        Bro, deberías aplicar a Platzi contrtibutors, estas notas podrían ser notas oficiales de la clase y aparecer abajo del video.

      Roberto Contrera

      Roberto Contrera

      student•
      hace 2 años

      ¿Cómo sería socket.connectedRoom en typescript?

      Julian David Alzate Cuervo

      Julian David Alzate Cuervo

      student•
      hace 2 años

      si en algun momento no les sirve para ver los mensajes, hay que matar el proceso y volver a correrlo o recargar la página borrando el caché

      Ameth Ordoñez Erazo

      Ameth Ordoñez Erazo

      student•
      hace 3 años
      .room { display: block; border: 2px solid #000; margin-bottom: 20px; }
      Henry Corredor

      Henry Corredor

      student•
      hace 3 años

      no acabo de entender por qué lo del punto y coma es una buena práctica y no una preferencia personal :/

        Fernando Francisco López Mauro

        Fernando Francisco López Mauro

        student•
        hace 3 años

        A veces el no porner ; genera algunos errores inesperados :)

        Diego Reyes Cabrera

        Diego Reyes Cabrera

        student•
        hace 2 años

        Mmmm no, no genera errores inesperados. Podrían ser casos muy específicos y pues, editores modernos con TypeScript y/o ESLint te avisarán si algo está mal

      Andrés Esteban Rodríguez Jiménez

      Andrés Esteban Rodríguez Jiménez

      student•
      hace 3 años

      Creación de salas

      Ya vimos como usar los broadcast para la manipulación de eventos en tiempo real sin que afecte nuestra lógica de cliente y se comparta en tiempo real con el resto de usuarios.

      Ahora, vamos a ver como podemos crear salas individuales donde mandemos eventos únicamente a la sala donde estemos participando.

      Supongamos que deseamos crear un chat grupal dividido por salas, como discord pero no tan complejo XD.

      Para esto vamos a volver a vaciar todo nuestro contenido del código y haremos lo siguiente:

      En nuestro archivo HTML agregaremos lo siguiente:

      <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <link rel="stylesheet" href="css/style.css"> <title>Servidor con Express y Socket.io</title> </head> <body> <ul class="room" id="room-1"></ul> <ul class="room" id="room-2"></ul> <ul class="room" id="room-3"></ul> <button id="connect-room-one">Room 1</button> <button id="connect-room-two">Room 2</button> <button id="connect-room-three">Room 3</button> <br> <button id="send-message">Enviar mensaje</button> <script src="/socket.io/socket.io.js"></script> <script src="js/index.js"></script> </body> </html>

      En nuestro CSS vamos a hacerlo un poco más sencillo:

      .room { display: block; border: 2px solid #000; margin-bottom: 20px; }

      Bien, ya tenemos la estructura básica de nuestro mini proyecto, ahora, vamos a ver como sería la lógica de nuestro cliente:

      const socket = io() // seleciono mis 3 botones const connectRoom1 = document.querySelector('#connect-room-one') const connectRoom2 = document.querySelector('#connect-room-two') const connectRoom3 = document.querySelector('#connect-room-three') // 1. eventos para conectarme a una sala específica connectRoom1.addEventListener('click', () => { socket.emit('connect-to-room', 'room-1') }) connectRoom2.addEventListener('click', () => { socket.emit('connect-to-room', 'room-2') }) connectRoom3.addEventListener('click', () => { socket.emit('connect-to-room', 'room-3') }) // 1. enviar mensaje const sendMessageButton = document.querySelector('#send-message') sendMessageButton.addEventListener('click', () => { // enviamos nuestro mensaje al servidor const message = prompt('Escribe tu mensaje') socket.emit('message', message) }) // 2. recibimos el evento del mensaje socket.on('send-message', data => { const { room, message } = data const li = document.createElement('li') li.textContent = message document.querySelector(`#${room}`).append(li) })

      Y ahora veamos como sería la lógica de nuestro servidor

      io.on('connection', socket => { socket.on('connect-to-room', room => { // creamos una propiedad personalizada en nuestro socket que será igual a la sala donde estamos conectados socket.connectedRoom = '' // antes de que el usuario entre a una sala, lo sacamos de la sala donde estaba socket.leave(socket.connectedRoom) // 1. el método join() nos permite ingresar nuestro socket a una sala que si existe nos mete y si no la crea switch (room) { case 'room-1': socket.join('room-1') socket.connectedRoom = 'room-1' break; case 'room-2': socket.join('room-2') socket.connectedRoom = 'room-2' break; case 'room-3': socket.join('room-3') socket.connectedRoom = 'room-3' break; default: break; } }) // 2. recibimos el mensaje en el servidor socket.on('message', (message) => { // recibimos la sala donde estamos conectados const room = socket.connectedRoom // aquí mandamos al mensaje a la sala deseada con el método de io.to() // en nuestro emit mandamos el mensaje y la sala io.to(room).emit('send-message', { message, room }) }) })

      Y listo, así hemos creado distintas salas donde podemos enviar información en tiempo real!

      Carlos Eduardo Bracho Ramírez

      Carlos Eduardo Bracho Ramírez

      student•
      hace 3 años

      Increíble! Desarrollé un pequeño clon de Discord con Firebase como ejercicio. Creo que al finalizar el curso probaré con Socket io.

      Pedros Pablo Montes

      Pedros Pablo Montes

      student•
      hace 2 años
      quiero compartir mi código :)

      le puse un select para escoger el chat en el que se va a mandar el mensaje y unos checkbox para suscribirse a las salas. Espero les sea utlil.

      https://github.com/PedroPab/WebSocket/tree/Chats

    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