Nodejs+Socket.io实现通讯实例代码
目录结构
成都创新互联公司是一家集网站建设,无极企业网站建设,无极品牌网站建设,网站定制,无极网站建设报价,网络营销,网络优化,无极网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
D:. │ package.json │ server.js │ └─public index.html socket.io.js
需要的条件
- socket.io.js 供前端界面初始化io
- socket.io 供NodeJs端提供socket方法
socket.io.js存在于socket.io-client
socket.io存在于socket.io
演示的功能
- 客户端发送消息给服务端
- 后端触发事件告知客户端
- 客户端离开触发服务端事件
服务端
server.js
var express = require('express'); var app = express(); var server = require('http').createServer(app); var io = require('socket.io')(server); app.use('/', express.static(__dirname + '/public')); server.listen(80); //socket部分 io.on('connection', function(socket) { //接收并处理客户端的hi事件 socket.on('hi', function(data) { console.log(data); //触发客户端事件c_hi socket.emit('c_hi','hello too!') }) //断开事件 socket.on('disconnect', function(data) { console.log('断开',data) socket.emit('c_leave','离开'); //socket.broadcast用于向整个网络广播(除自己之外) //socket.broadcast.emit('c_leave','某某人离开了') }) });
- connection用来处理socket链接事件
- disconnect处理连接断开事件
- 后端接受前端事件通过
socket.on(EventName,function(date){})
- 后端触发前端事件通过
socket.emit(EventName,msg)
这个后端演示了,前端发送消息给后端,触发hi事件,hi事件通过回调在触发客户端定义的c_hi事件告知前端。
客户端
index.html
socket
- 发送消息按钮用来给服务端发送信息,触发服务端定义的hi事件。
- 离开页面按钮用来离开页面,也就是socket会自动断开。触发服务端定义的disconnect。
源码下载:Socket_jb51.rar
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。
当前文章:Nodejs+Socket.io实现通讯实例代码
分享路径:http://pwwzsj.com/article/jgihcs.html