使用socket.io如何实现聊天室
程序员文章站
2022-04-07 08:06:12
...
这篇文章主要介绍了使用socket.io实现简单聊天室案例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了socket.io实现简单聊天室的具体代码,供大家参考,具体内容如下
1、客户端【index.html】代码:
<body> <h3>socket简例</h3> <hr> <p id = 'app'> <p> <p> <ul> <li v-for = 'item in msgs'> {{item.name}}说:{{item.content}} </li> </ul> </p> <p> <p><input type="text" v-model = 'msg'><button @click = 'm_send()'>发送</button></p> </p> </p> </p> <script type="text/javascript" src = 'https://cdn.bootcss.com/vue/2.5.9/vue.min.js'></script> <script type="text/javascript" src = 'https://cdn.bootcss.com/socket.io/1.7.3/socket.io.min.js'></script> <script type="text/javascript"> var _vm = new Vue({ data : { name : '用户', msg : '', msgs : [], }, methods : { m_send : function() { // 向客户端发送消息 socket_client.emit('say_client', { name : this.name, content : this.msg }) ; this.msg = '' ; } } }).$mount('#app') ; // socket服务器 var socket_client = io.connect('http://127.0.0.1:3000') ; /** * 监听服务端发来的消息 * * 1、“say_server”是客户端发出信息时的key值 * 2、“res”是客户端传来的value值 */ socket_client.on('say_server' ,function(res){ console.log('服务端发来的消息为:', res) ; _vm.msgs.push(res); }); </script> </body>
2、服务端【app.js】代码:
const http = require('http') ; const server = http.createServer() ; // web服务器 const express = require('express') ; const app = express(); app.use(express.static(__dirname + '/public')); app.listen(8888, function () { console.log('web服务器成功启动了,IP:127.0.0.1,端口号:8888') ; }); // socket服务器 const socketio = require('socket.io') ; const socket_server = socketio(server) ; // 建立和客户端的socket连接 socket_server.on('connection', function(client) { // console.log(client) ; // 查看连接进来的客户端对象内容 // console.log(Object.keys(client)) ; // 查看连接进来的客户端对象的关键key值 /** * 监听客户端发来的消息 * * 1、“say_client”是客户端发出信息时的key值 * 2、“res”是客户端传来的value值 */ client.on('say_client', function(res) { console.log('客户端发来的消息为:', res) ; // 向客户端发送消息 socket_server.emit('say_server', res) ; }) ; }) ; server.listen(3000, function() { console.log('socket服务器成功启动了,IP:127.0.0.1,端口号:3000') ; }) ;
上面是我整理给大家的,希望今后会对大家有帮助。
相关文章:
以上就是使用socket.io如何实现聊天室的详细内容,更多请关注其它相关文章!
上一篇: BOM与DOM的区别分析
下一篇: PHP比较运算符的种类
推荐阅读
-
IOS如何使用CAShapeLayer实现复杂的View的遮罩效果
-
视频如何实现批量压缩?使用迅捷压缩批量压缩视频的方法
-
如何使用localstorage代替cookie实现跨域共享数据问题
-
小程序云开发教程如何使用云函数实现点赞功能
-
[Oracle] 如何使用触发器实现IP限制用户登录
-
使用WebSocket实现即时通讯(一个群聊的聊天室)
-
Android应用程序四大组件之使用AIDL如何实现跨进程调用Service
-
Cwrsync如何使用可以实现Linux与windows下的文件同步详解
-
JavaScript编程开发如何使用jquery实现iframe自适应高度
-
PHP中如何使用session实现保存用户登录信息