Node.js + express + socket 实现在线实时多人聊天室

项目目录结构:




前端部分:


登录页面Login部分:


login.html


<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>login</title>
    <link rel="stylesheet" href="css/login.css">
</head>

<body>
    <div class="login-box flex-box">
        <!--登录标题栏-->
        <h2 class="sign-title box-width">LOGIN</h2>
        <!--头像栏-->
        <div class="picture-carousel">
            <div class="arrow left-arrow">
                <div class="before-arrow"></div>
            </div>
            <img class="p1 img-setting" src="img/1.png" alt="1.png">
            <img class="p2 img-setting" src="img/2.png" alt="2.png">
            <img class="p3 img-setting" src="img/3.png" alt="3.png">
            <img class="p2 img-setting" src="img/4.png" alt="4.png">
            <img class="p1 img-setting" src="img/5.png" alt="5.png">
            <div class="arrow right-arrow">
                <div class="after-arrow"></div>
            </div>
        </div>
        <!--用户名栏-->
        <div class="name-box box-width">
            <input type="text" class="user-name box-width" placeholder="Please Type Your Name">
        </div>
        <!--确认栏-->
        <div class="button-box box-width">
            <input type="button" class="login-button box-width" value="Login The Chatroom">
        </div>
        <!--错误信息栏-->
        <div class="error-box box-width">
            <span class="error-message">Welcome to chatroom!</span>
        </div>
    </div>
</body>
<script src="js/login.js"></script>

</html>

login.css

* {
    padding: 0;
    margin: 0;
    font-family: "Microsoft Yahei";
}

html,
body {
    width: 100%;
    height: 100%;
    font-family: "Microsoft Yahei";
    display: flex;
    justify-content: center;
    align-items: center;
}

body {
    background: linear-gradient(-135deg, #51D15B, #42A855);
    background: -moz-linear-gradient(-135deg, #51D15B, #42A855);
    background: -webkit-linear-gradient(-135deg, #51D15B, #42A855);
    background: -o-linear-gradient(-135deg, #51D15B, #42A855);
}

.flex-box {
    display: flex;
    justify-content: center;
    align-items: center;
}

.box-width {
    width: 80%;
}


/*最外层*/

.login-box {
    width: 20%;
    min-width: 304px;
    max-width: 404px;
    height: 50%;
    min-height: 368px;
    max-height: 468px;
    flex-direction: column;
    box-shadow: 1px 1px 15px #7B8C99;
    background: #fff;
}


/*LOGIN标题*/

.sign-title {
    color: #42A855;
    border: 2px solid #42A855;
    border-top: transparent;
    border-left: transparent;
    border-right: transparent;
}


/*图片切换*/

.picture-carousel {
    position: relative;
    display: flex;
    margin: 10%;
}


/*图片切换箭头*/

.arrow {
    z-index: 3;
    position: absolute;
    font-size: 60px;
    height: 100%;
    width: 30%;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #ffffff;
}

.arrow:hover {
    cursor: pointer;
}

.left-arrow {
    left: 0;
}

.before-arrow {
    width: 0px;
    height: 0px;
    border-width: 30px;
    border-style: solid;
    border-color: transparent #51D15B transparent transparent;
}

.right-arrow {
    right: 0;
}

.after-arrow{
     width: 0px;
    height: 0px;
    border-width: 30px;
    border-style: solid;
    border-color: transparent  transparent transparent #51D15B; 
}

.picture-carousel img {
    width: 80px;
    height: 80px;
    transition: all 0.2s linear;
    -moz-transition: all 0.2s ease-out;
    -webkit-transition: all 0.2s ease-out;
    -o-transition: all 0.2s ease-out
  • 8
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,要使用Node.jsSocket.io搭建一个基本的聊天室,可以参考以下步骤: 1. 安装Node.js和npm 2. 创建一个新的Node.js项目并在项目文件夹里打开命令行 3. 在命令行中输入以下命令来安装Socket.io: ``` npm install socket.io ``` 4. 创建一个新的文件夹用于存放服务器端代码,我们称之为“server” 5. 在“server”文件夹中创建一个新的JavaScript文件,例如“server.js” 6. 在“server.js”中添加以下代码: ``` const io = require('socket.io')(); io.on('connection', (socket) => { console.log('a user connected'); socket.on('disconnect', () => { console.log('user disconnected'); }); }); io.listen(3000); ``` 7. 在命令行中进入“server”文件夹并运行“server.js”文件: ``` node server.js ``` 8. 创建一个新的文件夹用于存放客户端代码,我们称之为“client” 9. 在“client”文件夹中创建一个新的HTML文件,例如“index.html” 10. 在“index.html”中添加以下代码: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>Socket.io Chat Room</title> </head> <body> <h1>Socket.io Chat Room</h1> <div id="messages"></div> <form id="message-form"> <input type="text" id="input-message" placeholder="Type your message here..."> <button type="submit">Send</button> </form> <script src="https://cdn.socket.io/socket.io-3.0.1.min.js"></script> <script src="client.js"></script> </body> </html> ``` 11. 在“client”文件夹中创建一个新的JavaScript文件,例如“client.js” 12. 在“client.js”中添加以下代码: ``` const socket = io('http://localhost:3000'); const messageForm = document.getElementById('message-form'); const inputMessage = document.getElementById('input-message'); const messages = document.getElementById('messages'); messageForm.addEventListener('submit', (event) => { event.preventDefault(); const message = inputMessage.value; if (message) { socket.emit('chat message', message); inputMessage.value = ''; } }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 13. 在命令行中进入“client”文件夹并运行以下命令: ``` npm install express ``` 14. 在“client”文件夹中创建一个新的JavaScript文件,例如“server.js” 15. 在“server.js”中添加以下代码: ``` const express = require('express'); const app = express(); app.use(express.static('public')); app.listen(8080, () => { console.log('Server running on http://localhost:8080'); }); ``` 16. 在命令行中进入“client”文件夹并运行以下命令: ``` node server.js ``` 现在你就可以在浏览器中打开“http://localhost:8080”并开始聊天了。 要实现私聊和创建群聊的功能,你需要在服务器端和客户端中添加一些额外的代码。 对于私聊功能,你可以创建一个“私聊房间”,只有被邀请的用户才能加入该房间,并在该房间中进行私人对话。以下是一些可能有用的代码: 1. 服务器端: ``` const users = {}; io.on('connection', (socket) => { console.log('a user connected'); socket.on('login', (username) => { users[username] = socket.id; console.log(`${username} logged in`); }); socket.on('invite', (username) => { const roomId = `${socket.id}:${users[username]}`; socket.join(roomId); io.to(users[username]).emit('invited', roomId); }); socket.on('chat message', (data) => { const { message, roomId } = data; io.to(roomId).emit('chat message', message); }); socket.on('disconnect', () => { console.log('user disconnected'); }); }); ``` 2. 客户端: ``` const socket = io('http://localhost:3000'); const username = prompt('What is your name?'); socket.emit('login', username); let roomId = null; const inviteForm = document.getElementById('invite-form'); const inviteInput = document.getElementById('invite-input'); inviteForm.addEventListener('submit', (event) => { event.preventDefault(); const username = inviteInput.value; if (username) { socket.emit('invite', username); inviteInput.value = ''; } }); socket.on('invited', (id) => { roomId = id; messages.innerHTML = ''; messageForm.style.display = 'block'; }); messageForm.addEventListener('submit', (event) => { event.preventDefault(); const message = inputMessage.value; if (message) { socket.emit('chat message', { message, roomId }); inputMessage.value = ''; } }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 对于创建群聊功能,你可以创建一个“群聊房间”,所有用户都可以加入该房间,并在该房间中进行群聊。以下是一些可能有用的代码: 1. 服务器端: ``` const rooms = {}; io.on('connection', (socket) => { console.log('a user connected'); socket.on('create room', () => { const roomId = socket.id; socket.join(roomId); rooms[roomId] = { name: `Room ${Object.keys(rooms).length + 1}` }; io.to(roomId).emit('room created', roomId); console.log(`Room ${roomId} created`); }); socket.on('join room', (roomId) => { socket.join(roomId); io.to(roomId).emit('user joined', { username: 'anonymous', message: 'joined the chat' }); console.log(`User ${socket.id} joined room ${roomId}`); }); socket.on('chat message', (data) => { const { message, roomId } = data; io.to(roomId).emit('chat message', message); }); socket.on('disconnect', () => { console.log('user disconnected'); }); }); ``` 2. 客户端: ``` const socket = io('http://localhost:3000'); const createRoomButton = document.getElementById('create-room-button'); const joinRoomForm = document.getElementById('join-room-form'); const joinRoomInput = document.getElementById('join-room-input'); createRoomButton.addEventListener('click', () => { socket.emit('create room'); }); joinRoomForm.addEventListener('submit', (event) => { event.preventDefault(); const roomId = joinRoomInput.value; if (roomId) { socket.emit('join room', roomId); joinRoomInput.value = ''; messages.innerHTML = ''; messageForm.style.display = 'block'; } }); socket.on('room created', (roomId) => { const option = document.createElement('option'); option.value = roomId; option.textContent = `Room ${Object.keys(rooms).length}`; selectRoom.appendChild(option); }); socket.on('user joined', (data) => { const { username, message } = data; const li = document.createElement('li'); li.textContent = `${username} ${message}`; messages.appendChild(li); }); socket.on('chat message', (message) => { const li = document.createElement('li'); li.textContent = message; messages.appendChild(li); }); ``` 以上代码只是一个简单的示例,你可以根据自己的需求进行更改和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值