سلام دوستان عزیز، صادق جعفری هستم. امروز قصد دارم شما را با روند ساخت یک اپلیکیشن چت در React با استفاده از Socket.IO آشنا کنم. امیدوارم این مقاله برای شما مفید واقع شود و بتوانید با استفاده از آن پروژههای خود را بهبود بخشید.
React یکی از محبوبترین کتابخانههای جاوااسکریپت برای ساخت رابط کاربری است. این کتابخانه توسط فیسبوک توسعه یافته و به دلیل سرعت بالا و سادگی در استفاده، بسیار مورد توجه قرار گرفته است. از سوی دیگر، Socket.IO یک کتابخانه قدرتمند برای برقراری ارتباط real-time بین سرور و کلاینت است که بر پایه WebSockets کار میکند.
برای شروع، ابتدا باید محیط توسعه خود را آماده کنید. مطمئن شوید که Node.js و npm را نصب کردهاید. سپس با استفاده از دستور npx create-react-app chat-app
یک پروژه جدید React ایجاد کنید. پس از آن، باید Socket.IO را به پروژه خود اضافه کنید. با اجرای دستور npm install socket.io-client
در ترمینال، کتابخانه Socket.IO را نصب کنید.
در این مرحله نیاز داریم تا یک سرور ساده Node.js راهاندازی کنیم که بتواند پیامها را بین کلاینتها مدیریت کند. یک فایل جدید به نام server.js
ایجاد کنید و کد زیر را در آن قرار دهید:
const express = require('express');
const http = require('http');
const socketIo = require('socket.io');
const app = express();
const server = http.createServer(app);
const io = socketIo(server);
io.on('connection', (socket) => {
console.log('A user connected');
socket.on('message', (msg) => {
io.emit('message', msg);
});
socket.on('disconnect', () => {
console.log('A user disconnected');
});
});
server.listen(4000, () => {
console.log('Server is running on port 4000');
});
حال که سرور ما آماده است، باید کلاینت را به آن متصل کنیم. در فایل App.js
پروژه React خود، کد زیر را اضافه کنید:
import React, { useState, useEffect } from 'react';
import io from 'socket.io-client';
const socket = io('http://localhost:4000');
function App() {
const [message, setMessage] = useState('');
const [messages, setMessages] = useState([]);
useEffect(() => {
socket.on('message', (msg) => {
setMessages((prevMessages) => [...prevMessages, msg]);
});
}, []);
const sendMessage = () => {
socket.emit('message', message);
setMessage('');
};
return (
<div>
<h1>Chat Application</h1>
<div>
{messages.map((msg, index) => (
<div key={index}>{msg}</div>
))}
</div>
<input
type="text"
value={message}
onChange={(e) => setMessage(e.target.value)}
/>
<button onClick={sendMessage}>Send</button>
</div>
);
}
export default App;
در این مرحله میتوانیم بهینهسازیهای بیشتری روی اپلیکیشن انجام دهیم. میتوانیم سیستمهای احراز هویت، مدیریت کاربران، نمایش زمان ارسال پیامها و ... را اضافه کنیم. به عنوان مثال، میتوانیم از کتابخانههای JWT برای احراز هویت و Moment.js برای مدیریت زمان استفاده کنیم.
ساخت یک اپلیکیشن چت با استفاده از React و Socket.IO نه تنها آسان است، بلکه تجربهای عالی برای توسعهدهندگان فراهم میکند تا با مفاهیم پیشرفتهتری مانند WebSockets و real-time communication آشنا شوند.
امیدوارم این مقاله برای شما مفید بوده باشد. نظرات و سوالات خود را با من در میان بگذارید.
با تشکر، صادق جعفری
صادق جعفری
از کودکی به کامپیوتر و دنیای دیجیتال علاقه داشتم، به همین دلیل ترک تحصیل کردم و تمام تلاش خودم را صرفا برای یادگیری کامپیوتر، طراحی، برنامه نویسی و ... به کار گرفتم. در کنار مشاغل مختلفی که مجبور به انجامشان بودم برنامه نویسی را یاد گرفتم و از سال 1390 وارد بازار کار شدم و همیشه در تلاش هستم تا چالش های روبرو را با موفقیت پشت سر بگذارم.
شبکه های اجتماعی من