最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
详解如何使用koa实现socket.io官网的例子
时间:2022-06-25 15:29:39 编辑:袖梨 来源:一聚教程网
socket.io官网中使用express实现了一个最简单的IM即时聊天,今天我们使用koa来实现一下
### 框架准备
1.确保你本地已经安装好了nodejs和npm,使用koa要求node版本>7.6
2.在你需要的位置新建一个文件夹(官网的简单命名为chat-example)
3.进入项目目录,创建package.json文件:
{
"name": "socket-chat-example",
"version": "0.0.1",
"description": "my first socket.io app",
"dependencies": {}
}
4.命令行中使用npm安装,执行以下命令
npm install --save koa koa-router http fs socket.io
### 接下来直接上代码
项目目录下直接新建index.js
var Koa = require('koa');
var app = new Koa();
const Router = require('koa-router');
const fs = require('fs');
const server = require('http').createServer(app.callback());
const io = require('socket.io')(server);
// 首页路由
let router = new Router();
router.get('/', ctx => {
ctx.response.type = 'html';
ctx.response.body = fs.createReadStream('./index.html');
});
app.use(router.routes());
// socket连接
io.on('connection', (socket) => {
socket.on('chat message', (msg) => {
console.log('message: '+msg);
io.emit('chat message', msg);
});
socket.on('disconnect', () => {
console.log('user disconnected');
});
});
// 监听端口
server.listen(3000, () => {
console.log('listening on *:3000');
});
重点:
socket的连接方式是先建立server,它的获取方式不再是:
var http = require('http').Server(app);
var io = require('socket.io')(http);
而变成了:
const server = require('http').createServer(app.callback());
const io = require('socket.io')(server);
node8之后,function(){} 可以简化为 () => {},写法上更加的简洁
页面index.html
Socket.IO chat
index.html和官网的一样,不做任何改动
最后执行node index.js,打开浏览器,输入http://l**ocalho*st:3000就可以实现最简单的聊天了
相关文章
- 龙腾世纪4影障守护者生命上限提高方法 11-02
- 曾仕强语录经典96句 11-02
- 龙腾世纪4影障守护者增加击晕效果方法 11-02
- 龙腾世纪4影障守护者快速击晕敌人方法 11-02
- 龙腾世纪4影障守护者支线任务寻找方法 11-02
- 龙腾世纪4影障守护者迪梅塔市长选择攻略 11-02