Bacancy Bacancy
      • About Company
      • Resources

      About Company

      About Us Leadership Team Customer Reviews Awards & Recognition
      Infrastructure Our Locations Partnership

      Resources

      Press Room Blog Insights
      We are great place to work certified™

      Building and Sustaining High-Trust, High-Performance Culture

      Get Quote
    • Engagement Models

      Hiring Software Developers becomes easier with just a few clicks.

      Software Development Outsourcing

      End-to-end delivery of custom solutions aligned to your roadmap.

      Staff Augmentation

      Scale your in-house team with pre-vetted specialists on demand.

      Dedicated Teams

      Get dedicated engineers who work exclusively on your project.

      • Enterprise Services
      • IT Services
      • Data Analytics
      • Cloud Services
      • AI & ML
      • Platforms

      Enterprise Services

      Digital Transformation Business Process Automation Digital Product Engineering Enterprise App Development Custom Software Development

      IT Services

      Legacy App Modernization DevOps & SRE Full Stack Development AI Testing & QA Automation

      Data Analytics

      Data Visualization & Reporting Data Engineering & Pipelines Data Science & Predictive Analytics Business Intelligence

      Cloud Services

      Cloud Strategy & Consulting Cloud Migration & Modernization Multi Cloud Management

      AI & ML

      AI Development Agentic AI Generative AI Computer Vision Machine Learning & MLOps

      Platforms

      Salesforce SAP ServiceNow Microsoft Dynamics Snowflake
      High-quality, Cost-effective IT Outsourcing

      Schedule a free discovery session to explore your needs and find tailored solutions with no obligation.

      explore all services
    • Industries
      Healthcare Fintech Real Estate
      Logistics Education Retail & Ecommerce
      Let's Grow Together! Get Quote
      • Front End
      • Backend
      • Mobile
      • Databases
      • DevOps & Infra
      • AI & Data Stack
      • Vibe Coding

      Front End

      React.js Next.js Angular Vue.js TypeScript
      Your Very Own UI/UX Architects

      Experience smooth navigation and user-friendly designs with our front-end expertise.

      Hire Frontend Developer

      Backend

      Node.js Python Java Spring Boot Laravel .NET C# Golang FastAPI
      Server Solutions To Change Power Dynamics

      Transform your data into digital experiences with optimized coding standards.

      Hire Backend Developer

      Mobile

      iOS Android Flutter React Native
      Innovating Mobile-Friendly App Solutions

      Create dynamic mobile apps that make your brand stand out from the crowd.

      Hire Mobile App Developer

      Databases

      PostgreSQL MongoDB MySQL Redis Supabase
      Dedicated Talent With Skilled Approach

      Bring your digital visions to life with a hired resource at your convenience.

      Hire Dedicated Developer

      DevOps & Infra

      AWS Azure Google Cloud Docker Kubernetes Terraform
      Redefining Scalable Digital Infrastructures

      Make your data accessible worldwide at will, and leave the stress behind.

      Get Quote

      AI & Data Stack

      OpenAI LangChain LlamaIndex Apache Spark Airflow Tableau PowerBI Databricks
      Guiding Decisions With Data-Driven Insights

      Transition from your gut calls to actionable insights with our rich Data Science expertise.

      Get Quote

      Vibe Coding

      Base44 Claude Code Cursor Lovable Github Copilot
      Your AI-Native Development Team

      Skip the boilerplate. Our vibe coding experts use AI-first tools to go from prompt to product, fast.

      Hire Vibe Coding Developer
  • Case Studies
  • Contact Us
Find a Developer book a 30 min call
      • About Us
      • Leadership Team
      • Customer Reviews
      • Awards & Recognition
      • Infrastructure
      • Our Locations
      • Partnership
      • Press Room
      • Blog
      • Insights
      • Digital Transformation
      • Business Process Automation
      • Digital Product Engineering
      • Enterprise App Development
      • Custom Software Development
      • Legacy App Modernization
      • DevOps & SRE
      • Full Stack Development
      • AI Testing & QA Automation
      • Data Visualization & Reporting
      • Data Engineering & Pipelines
      • Data Science & Predictive Analytics
      • Business Intelligence
      • Cloud Strategy & Consulting
      • Cloud Migration & Modernization
      • Multi Cloud Management
      • AI Development
      • Agentic AI
      • Generative AI
      • Computer Vision
      • Machine Learning & MLOps
      • Salesforce
      • SAP
      • ServiceNow
      • Microsoft Dynamics
      • Snowflake
    • Healthcare
    • Fintech
    • Real Estate
    • Logistics
    • Education
    • Retail & Ecommerce
      • React.js
      • Next.js
      • Angular
      • Vue.js
      • TypeScript
      • Hire Frontend Developer
      • Node.js
      • Python
      • Java
      • Spring Boot
      • Laravel
      • .NET
      • C#
      • Golang
      • FastAPI
      • Hire Backend Developer
      • iOS
      • Android
      • Flutter
      • React Native
      • Hire Mobile App Developer
      • PostgreSQL
      • MongoDB
      • MySQL
      • Redis
      • Supabase
      • Hire Dedicated Developer
      • AWS
      • Azure
      • Google Cloud
      • Docker
      • Kubernetes
      • Terraform
      • Get Quote
      • OpenAI
      • LangChain
      • LlamaIndex
      • Apache Spark
      • Airflow
      • Tableau
      • PowerBI
      • Databricks
      • Get Quote
      • Base44
      • Claude Code
      • Cursor
      • Lovable
      • Github Copilot
      • Hire Vibe Coding Developer
  • Case Studies
  • Contact Us
  • Find a Developer
  • book a 30 min call
Chat App with Express, ReactJS, and Socket.IO

How to Build Real-time Chat App with Express, ReactJS, and Socket.IO?

Vivek Patel
Vivek Patel Full Stack Developer
Last Updated on November 21, 2025 | Written By: Vivek Patel

I have always been very interested in learning how the live user interactions in real-time chat applications work? Such web applications always excite me to find the answer of how to build real-time chat app. To quench my thirst for knowledge, I started reading blogs and watching tutorials. After getting my hands on building a real-time chat app with Express, ReactJS, and Socket.IO, I decided to write a blog on it, as it was once said by Margaret Fuller, “If you have the knowledge, let others lit their candles in it.”

Table of Index

1. Overview

2. What is Socket.IO? And how does it work?

3. How to build the chat app with Express, ReactJS, and Socket.IO?

4. Conclusion

Overview

It might seem quite challenging when you read the topic – How to build a Chat App with Express, React, and Socket.io? This blog will surely take care of that challenge, and I’ll try my best to make it as simple as possible. So, let’s take the challenge and move ahead with a positive quote I read somewhere –

“We don’t grow when things are easy. We grow when we face challenges.”

Before starting the coding part, I would like to give some preliminary information about What is Socket.IO? You can skip this part and head towards the coding section if you’re familiar with Socket.IO already.

What is Socket.IO? And How Does it Work?

Socket.IO was developed for real time applications that can communicate and develop live user-interaction. As the documentation of Socket.IO states –

Socket.IO is a library that enables real-time, bidirectional, and event-based communication between the browser and the server.

With the help of Engine.IO, Socket.IO establishes the connection and permits bidirectional communication between client and server. The bidirectional communication takes place only when the client and server both have Socket.IO integrated. It transfers data in various forms, but the most likely in JSON format.

Socket.IO transfers data from the client of the particular server to the server, and then that server transmits it to other clients. This is how the transfer of information takes place.

I hope you now have a better understanding of Socket.IO. You can visit its documentation to start your Socket.IO tutorial. Finally, it’s time to build your own real time chat app. As a full stack development company, we at Bacancy have helped numerous projects leverage the combined power of frontend frameworks and backend socket infrastructure to build scalable, real-time applications.

How to Build a Real-time Chat App with Express, ReactJS, and Socket.IO?

I assume that you have Node.js V10 or higher version installed on your system. If not, then click here to install.

Starting with the basics

I’m creating here the main folder and then initiating it using NPM-

mkdir chat-app
cd chat-app

npm init

Setting up Express Server and Socket.IO

Once you click enter for all the options, install the Express library and Socket.IO for handling socket connections.

npm install --save express socket.io

After installing the Express and Socket.IO library, we will create a file to implement our new application’s logic.

touch server.js

Now we will write the express server code in the server.js file. Open your real-time chat-app and start editing it.

//server.js
let express = require('express')
let http = require('http')
let socket_IO = require('socket.io') 

const PORT = 8001 
let app = express() 
let server = http.Server(app) 
let io = socketIO(server) 

io.on('connection', (socket) => {
  console.log('User is connected sucessfully')
  
  socket.on('disconnect', () => {
    console.log('Sorry! User is unfortunately disconnected')
  })
})

server.listen(PORT, () => {
   console.log(`Running on port ${port}.`);
});

Now, by running the below-mentioned command, ensure the code is working as expected.

node server.js

Your console should display – Running on port 8001.

Close the server using ctrl+c

On hitting the URL – http:// localhost: 8001, you won’t see anything as we still need to work on our front-end. So far, we are a bit done with the socket listener in our sever.js file.

Now let’s move on to my favorite part of building the real time chat application, i.e., front-end.

Front-end part: React Component

We will be using create-react-app for it, some also prefer to configure Webpack, but that’s up to you. If you don’t have create-react-app installed on your system, use the below command-

npm i create-react-app

Now let’s create our React application –

create-react-app chat-app-client
cd chat-app-client

You can remove unwanted files like – favicon.ico and logo.svg from your file structure.

Now, as we know, Socket.IO uses Engines.IO, due to which we need to install Socket.IO at both client and server sides. So, it’s time to install socket.io-client

npm i socket.io-client

Client-Server Connection

This section will see how to connect the client with the server and enable communication in real time chat application using Socket.IO.

import React from 'react';
import socketClient from 'socket.io-client';
const SERVER = "http:// 127.0.0.1:8001";
function ChatApp() {
 let socket_io = socketClient(SERVER);
   return (
      < div >
        < p >Just checking if this is working!< /p >
      < /div >
    );
}
export default ChatApp;

Make these necessary changes in your server.js file so that the client listens to all the emitted events from the backend.

//server.js

let express = require('express')
let http = require('http')
let socketIO = require('socket.io') 

const PORT = 8001 
let app = express() 
let server = http.Server(app) 
let io = socketIO(server) 

const STATIC = [‘global_notif, global_chats’];

io.on(“connection”, (socket_io) => {
  console.log('User is connected successfully');
  socket_io.emit(“connection”, null);
  
  socket_io.on(“disconnect”, () => {
    console.log('Sorry! User is unfortunately disconnected');
  })
})

server.listen(PORT, () => {
   console.log(`Running on port ${port}.`);
});

Due to the function socket_io_emit, events can be emitted to the front end from the socket connection. Keep in mind that this transmission of data will be possible only with recently connected clients.

Now, the web socket connection is developed, so let’s proceed to build Chat.

How to Build Chat application?

We will have a folder named Chat, which will consist of our Channel’s components and the main Component of Chat. I won’t be adding CSS files for designing; instead, I’ll focus on the logic and components.

//Main_Chat.js

import React, { Component } from 'react';
import { Channels } from './Channels';

export class Main_Chat extends Component {
state = {
    all_channels: [
        { id: 10, name: 'John', members: 20}
      ]
    }
  render() {
     return (
        < div >
‍           < Channels all_channels={this.state.all_channels} / >
‍        < /div >
       );
    }
‍}

// Channels.js

import React, { Component } from 'react';

export class Channels extends Component {
   render() {
     let channel_list = `Sorry, No channels available`;
       if (this.props.all_channels) {
          list = this.props.all_channels.map(c =>  
          < p > {c.name} < /p >
       }
       return (
          < div >
             {channel_list}
‍          < /div >
        );
    }
‍}

So, we have two files here- Main_Chat.js and Channels.js. Main_Chat.js includes the Channels.js, which will display data related to the channel list using the prop all_channels. We are done with the Chat folder now, moving ahead to create a message folder for Message Panel. We will build two files in that folder, namely Main_Message.js and Messages.js.

//Main_Message.js

import React, { Component } from 'react';

export class Main_Message extends Component {
   render() {
      return (
          < div >
              < p >{this.props.senderName}< /p >
              < span >{this.props.text}< /span >
           < /div >
        )
    }
‍}

//Messages.js

import React, { Component } from 'react';
import { Main_Message } from './Main_Message';

export class Messages extends Component {
    render() {

        let msg_list = 
No messages!
; if (this.props.channel.messages) { const { msgs } = this.props list = msgs.channel.messages.map(msg => ) /> } return ( < > < p >{msg_list}< /p > ‍ < > < input type="text" > < button >Send< /button > ‍ < /> < /> ); } }

So far, we had set up the real time chat app with Express, ReactJS, and Socket.IO; now, without further ado, let’s move on to develop logic.

Logical part: Sending and Receiving Messages

We are done with the simple interface, and I hope you’ve managed your designing too. Moving on to focus on the logic part of our real time chat application, i.e., how to send and receive the messages?

How to fetch the channels?

Add the following code into your server.js file for retrieving the current channel’s data –

// server.js

app.get('/getAllChannels', (request, response) => {
   request.json({
       all_channels: STATIC
   })
‍});

This was for the backend side, write the following for frontend –

// Main_Chat.js

componentDidMount() {
   this.loadAllChannels();
‍}
loadAllChannels = async () => {         fetch('http:// localhost:8001/getAllChannels').then(async response => {
       let all_data = await response.json();
           this.setState({ all_channels: all_data.channels });
   })
‍}

Now, there’s a need for some events to be emitted and listeners in real time chat app. Whenever a channel is being selected, it should call an event that will eventually be handled in the backend. Also, the front-end has to look after the event. The front-end should have the same events emitted by the back-end to capture it and vice-versa.

// Main_Chat.js

handleSelect = (channel_id) => {
       this.socketIO.emit('channel-join', channel_id)
   }   
   render() {
    const { all_channels } = this.state;


return (
          < Channels all_channels={all_channels}   onChannelSelect={this.handleSelect} / >
       );
‍}

// server.js

io.on('connection', (socket_IO) => { 
    console.log('User is connected successfully!');
    socket_IO.emit('connection', null);
    socket_IO.on('channel_join', channel_id => {
        console.log('channel join', channel_id);
        STATIC.forEach(i => {
            if (i.id === channel_id) {
                if (i.sockets.indexOf(socket_IO.id) == (-1)) {
                    i.sockets.push(socket_IO.id);
                    i.members++;
                    io.emit('channel', c);
                }
            } else {
               let channel_index =              i.sockets.indexOf(socket_IO.id);
                if (channel_index != (-1)) {
                    i.sockets.splice(channel_index, 1);
                    i.members--;
                    io.emit('channel', c);
                }
            }
        });
 
        return channel_id;
    })
});

How to send messages?

Heading towards our last section of the blog – How to Build a Real-time Chat App with Express, ReactJS, and Socket.IO? After establishing a stable WebSocket connection, it’s time to learn how to send messages over it. This section will store the message typed in the textbox and then send that message by clicking Send. Open your Main_Chat.js file and make the necessary changes.

setUpSocketIO = () => {

 let socketIO = socketClient(SERVER);
 socketIO.on('connection', () => {
const { channels } = this.state;
   if (channels) {
     this.handleSelect(channels.id);
   }
 });

 socketIO.on('channel', channel => {
  
   let all_channels = this.state.all_channels;
    all_channels.forEach(i => {
       if (i.id === channel.id) {
         i.members = i.members;
       }
 });

 this.setState({ all_channels });});

socketIO.on('message', msg => {
 let all_channels = this.state.all_channels
   all_channels.forEach(i => {
     if (i.id === msg.channel_id) {
       if (!i.messages) {
         i.messages = [msg];
       } else {
         i.messages.push(msg);
       }
     }
   });
   this.setState({ all_channels });
 });

 this.socketIO = socketIO;
}
onSendingMessage = (id, msg) => {
 this.socketIO.emit('send-message', 
    { channel_id: id, 
     text: msg, 
     name: this.socketIO.id, 
     id: Date.now() 
    });
 }

render() {
const { all_channels } = this.state;
 return (
   < >
     < Channels all_channels={all_channels}      onChannelSelect={this.handleSelect} 
      / >    
     < Messages onSendMessage={this.onSendingMessage} channel={all_channel} / > 
   < />  
 );
‍}

So, this was for the front-end part. Implementation at the back-end is quite simpler than this; we just have to broadcast the messages.

socketIO.on('send-message', msg => {
   io.emit('message', msg);
‍})

This was all about how to build your own real time chat app with Express, ReactJS, and Socket.IO. I hope the purpose of landing on this blog has been satisfied. With the combination of ReactJs and Socket.IO, you can build brilliant real time chat applications.

Conclusion

Here at Bacancy Technology, we provide you the best guidance for various technologies, including ReactJs and NodeJs. You can find the best coding practices being followed by TDD and BDD here. If you are looking to hire full stack developer who can help you build a real-time chat app with Express, ReactJS, and Socket.IO, then you have landed on the right blog post. Get in touch with us to fulfill your custom business requirements.


Expand Your Digital Horizons With Us.

Start a new project or take an existing one to the next level. Get in touch to start small, scale-up, and go Agile.


Or
E-mail us : solutions@bacancy.com

Your Success Is Guaranteed !

Related Articles

Nikunj Padhiyar

February 5, 2026

Full Stack

Why Laravel + Svelte Is Becoming the Go-To Full-Stack Combo for High-Performance Web Apps

By : Nikunj Padhiyar

Read More
Dipal Bhavsar

October 29, 2025

Full Stack

Choosing the Right Tech Stack in 2026: From Mistakes to Smart Decisions

By : Dipal Bhavsar

Read More
Dipal Bhavsar

August 21, 2025

Full Stack

Why Django with React is the Perfect Full-Stack Match for High-Growth Businesses

By : Dipal Bhavsar

Django with React combines a powerful backend with an interactive frontend to build dynamic, scalable, and efficient web applications. This...

Read More

Offices and Development Centers

Bacancy Ahmedabad Ahmedabad

15-16, Times Corporate Park, Thaltej, Ahmedabad, 380059

Bacancy Gandhinagar Gandhinagar

422-A, 4th Floor, Pragya Tower Road 11, Block 15, Zone 1, SEZ-PA Gandhinagar, 382355

Bacancy Hyderabad Hyderabad

Awfis, Level 1, N Heights, Plot No 38, Phase 2, Hitech City Hyderabad, 500081

Bacancy Mumbai Mumbai

18th Floor, Cyberone, opp. CIDCO Exhibition Centre, Sector 30, Vashi, Navi Mumbai, 400703

Bacancy Pune Pune

2nd FloorMarisoft-1, Marigold IT Park, Pune - 411014

Bacancy Bengaluru Bengaluru

Raheja Towers, 26/27, Mahatma Gandhi Rd, East Wing, Craig Park Layout, Ashok Nagar, Bengaluru, 560001

Global Presence

Bacancy New Jersey New Jersey

33 South Wood Ave, Suite 600, Iselin NJ 08830

Bacancy California California

535 Mission St 14th floor, San Francisco, CA 94105

Bacancy Massachusetts Massachusetts

501 Boylston St, Boston, MA 02116

Bacancy Florida Florida

4995 NW, 72nd Avenue, Suite 307, Miami, FL, 33166

Bacancy London London

90 York Wy, London N1 9AG, United Kingdom

Bacancy Ontario Ontario

71 Dawes Road, Brampton, On L6X 5N9, Toronto

Bacancy Australia Australia

351A Hampstead Rd, Northfield SA 5085

Bacancy UAE UAE

One Central 8th and 9th Floor - Trade Centre - Trade Centre 2 - Dubai - United Arab Emirates

Bacancy Sweden Sweden

Junkergatan 4, 126 53 Hagersten

Get in Touch

Great Place to Work

Get in Touch

cal-icon

Looking for expert advice?

Schedule a Expert Call


  • Brochure
  • Quality Assurance
  • Resources
  • Tutorials
  • Customer Reviews
  • Privacy Policy
  • FAQs
  • Press Room
  • Contact Us
  • Sitemap
  • Employee

bacancy google review 4.6
bacancy google review
bacancy clutch review 4.8
bacancy clutch review
bacancy goodfirms review 4.8
bacancy goodfirms review
iso
  • Bacancy Behance
  • Bacancy Pinterest

Copyright © 2026 BACANCY SERVICES PRIVATE LIMITED All rights reserved.