Vue.js 如何使用 Socket.IO ?
在很多需求业务中,都需要浏览器和服务器实时通信来实现功能,比如:扫码登录(扫码后,手机确认登录,PC网页完成登录并跳转)、订单语言提醒等,这些都是建立在两端实时通信的基础上的。对前端而言,来实现浏览器和服务器实时通信,最好的选择就是Socket.IO库,能够快速的实现两端实时通信功能。
1、什么是 Socket.IO?
Socket.IO
是一个WebSocket库,可以在浏览器和服务器之间实现实时,双向和基于事件的通信。它包括:Node.js服务器库、浏览器的Javascript客户端库。它会自动根据浏览器从WebSocket、AJAX长轮询、Iframe流等等各种方式中选择最佳的方式来实现网络实时应用,非常方便和人性化,而且支持的浏览器最低达IE5.5
2、Socket.IO 主要特点
(1)、支持浏览器/Nodejs环境 (2)、支持双向通信 (3)、API简单易用 (4)、支持二进制传输 (5)、减少传输数据量
3、Vue.js 中 Socket.IO的使用
(1)客户端
npm install vue-socket.io --save
main.js添加下列代码
import VueSocketIO from 'vue-socket.io' Vue.use(new VueSocketIO({ debug: true, // 服务器端地址 connection: 'http://localhost:3000', vuex: { } }))
发送消息和监听消息
//发送信息给服务端 this.$socket.emit('login',{ username: 'username', password: 'password' }); //接收服务端的信息 this.sockets.subscribe('relogin', (data) => { console.log(data) })
(2)服务端
服务端,我们基于express搭建node服务器。
npm install --save express npm install --save socket.io
index.js文件
var app = require('express')(); var http = require('http').Server(app); var io = require('socket.io')(http); app.get('/', function(req, res){ res.send('<h1>你好web秀</h1>'); }); io.on('connection',function(socket) { //接收数据 socket.on('login', function (obj) { console.log(obj.username); // 发送数据 socket.emit('relogin', { msg: `你好${obj.username}`, code: 200 }); }); }); http.listen(3000, function(){ console.log('listening on *:3000'); });
然后启动服务端服务
node index.js
客户端即可查看效果。
4、Socket.IO有哪些事件
io.on('connect', onConnect); function onConnect(socket){ // 发送给当前客户端 socket.emit( 'hello', 'can you hear me?', 1, 2, 'abc' ); // 发送给所有客户端,除了发送者 socket.broadcast.emit( 'broadcast', 'hello friends!' ); // 发送给同在 'game' 房间的所有客户端,除了发送者 socket.to('game').emit( 'nice game', "let's play a game" ); // 发送给同在 'game1' 或 'game2' 房间的所有客户端,除了发送者 socket.to('game1').to('game2').emit( 'nice game', "let's play a game (too)" ); // 发送给同在 'game' 房间的所有客户端,包括发送者 io.in('game').emit( 'big-announcement', 'the game will start soon' ); // 发送给同在 'myNamespace' 命名空间下的所有客户端,包括发送者 io.of('myNamespace').emit( 'bigger-announcement', 'the tournament will start soon' ); // 发送给指定 socketid 的客户端(私密消息) socket.to(<socketid>).emit( 'hey', 'I just met you' ); // 包含回执的消息 socket.emit( 'question', 'do you think so?', function (answer) {} ); // 不压缩,直接发送 socket.compress(false).emit( 'uncompressed', "that's rough" ); // 如果客户端还不能接收消息,那么消息可能丢失 socket.volatile.emit( 'maybe', 'do you really need it?' ); // 发送给当前 node 实例下的所有客户端(在使用多个 node 实例的情况下) io.local.emit( 'hi', 'my lovely babies' ); };
5、Socket.IO全家桶

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
初学者也说TARS
作为一个应届毕业生,进入阅文集团,加入到通用平台中心之后,随着日常工作的逐步深入,我渐渐了解阅文的技术体系,其中尤其以腾讯TARS平台最为重要。目前TARS平台承载了阅文内部绝大多数的服务,每日接口调用最大值近百亿,单业务峰值可在数万每秒,近300个业务服务。作为一个新人,我来讲下我从TARS小白到熟练工的历程中整理的一些知识点。 TARS文件 TARS作为一个服务治理框架,最基础的还是要解决服务间调用的问题,这样就引入一个问题:如何在多个服务之间发布接口协议。TARS创新性的设计了一种接口描述语言,即TARS文件,在TARS文件中,可以编写模型、接口、枚举等。在服务提供方,我们可以通过tars-maven-plugin解析TARS文件,生成对应的模型、接口、枚举代码,然后就可以在接口实现类中进行业务逻辑的编写。在对外提供服务时,调用方只需要拿到服务提供方的TARS文件,就能了解服务提供的所有接口及相关描述,从而生成客户端调用代码,进行服务接口调用。 module TestApp { interface Hello { string hello(int no, string n...
- 下一篇
支撑马蜂窝会员体系全面升级背后的架构设计
流量红利正逐渐走向终结,这已经不再是什么秘密。后互联网时代,如何维系住用户群,提升用户在平台上的体验是整个行业都需要考虑的事情。正是出于这一原因,现在全行业都在关注会员体系的搭建,这也是马蜂窝 2019 年重点投入的方向之一。 面对这个全行业都在发力的会员市场,要对「马蜂窝特色」的会员体系进行有力的支撑,无疑对会员体系的架构设计提出更高的要求。 马蜂窝会员体系建设从 2018 年 9 月份开始启动,经过前期对会员身份和会员权益的摸索,伴随业务的快速发展,到 2019 年上半年,为了让更多用户体验到马蜂窝高质量的会员服务,公司推出了更灵活、维度更多、权益更丰富的会员模式。在这样的背景下,初期较为粗旷的底层技术也需要及时做出调整,对核心架构和服务进行升级。 一、会员身份策略改造 早期的会员身份模块由会员产品、用户属性和时间属性共同构成: 可以看到早期的会员产品比较单一,因此将产品信息设计成一级结构。这种设计的好处是逻辑简单,可以快速实现,但不易扩展,一旦新增会员类别以及不同卡种之间出现复杂关系时,不论是对项目或者对代码本身而言,维护成本都将成倍增长。 从 2019 年年初开始,马蜂窝会员体...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS8编译安装MySQL8.0.19
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果