vue使用websocket的详细步骤(vue使用webSocket更新实时天气的方法)
vue使用websocket的详细步骤
vue使用webSocket更新实时天气的方法目录
- 前言
- 关于 webSocket 的操作及示例:
- webSocket
- 1.关于 webSocket
- 2.与 AJAX 轮的区别
- 3.webSocket 事件
- 4. 一个简单的示例
- 天气更新
- 图片素材
- 重连机制
在 vue 中使用 webSocket 做一个简单的天气实时更新模块。
1.webSocket 连接
2.接收数据
3.重连机制
1.关于 webSocket
webSocket 是 HTML5 开始提供的一种在单个 TCP 连接上进行全双工通讯的协议。浏览器通过 JavaScript 向服务器发出建立 webSocket 连接的请求,连接建立以后,客户端和服务器端就可以通过 TCP 连接直接交换数据。
当你获取 Web Socket 连接后,你可以通过 send() 方法来向服务器发送数据,并通过 onmessage 事件来接收服务器返回的数据。
var Socket = new webSocket(url, [protocol] );
protocol 是可选的,指定了可接受的子协议
2.与 AJAX 轮的区别
现在,很多网站为了实现推送技术,所用的技术都是 Ajax 轮询。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发出HTTP请求,然后由服务器返回最新的数据给客户端的浏览器。 这种传统的模式带来很 明显的缺点,即浏览器需要不断的向服务器发出请求,然而HTTP请求可能包含较长的头部,其中真正有效的数据可能只是很小的一部分,显然这样会浪费很多的带宽等资源。
HTML5 定义的 webSocket 协议,能更好的节省服务器资源和带宽,并且能够更实时地进行通讯。
3.webSocket 事件
4. 一个简单的示例
通过上述简单介绍,我们来创建一个 webSocket 实例试一下:
function webSocketTest() { if ("webSocket" in window){ alert("您的浏览器支持 webSocket!"); // 打开一个 webSocket var ws = new webSocket("ws://localhost:8080/test"); ws.onopen = function() { // webSocket 已连接上,使用 send() 方法发送数据 ws.send("发送数据"); console.log("数据发送中..."); }; ws.onmessage = function (evt) { // 接收到的数据 var data = evt.data; console.log("数据已接收..."); }; ws.onerror = function () { // 连接报错 console.log('连接报错...'); } ws.onclose = function() { // 关闭 webSocket console.log("连接已关闭..."); }; } else { // 浏览器不支持 webSocket alert("您的浏览器不支持 webSocket!"); } }
可以看出,其实 webSocket 使用方法很简单:
1.判断浏览器是否支持 webSocket;
2.创建一个 webSocket 实例;
3.罗列 webSocket 事件并在相应事件中处理相应业务即可。
在vue中使用方法一样
天气更新此处展示一下前面说过的天气实时更新效果实现。项目框架为 vue\element。
基础代码
<!-- 布局 使用的element,直接使用即可 --> <el-popover placement="bottom" :title="weather.title" trigger="hover" :content="weather.cont"> <li slot="reference" class="weather"> <img :src="weather.url" alt=""> </li> </el-popover>
export default { data() { return { weather: { cityName: '', title: '--市/--℃', cont: '--', weatherCode: '0', url: '' } } }, methods: { // 获取天气 async getTheWeather() { // 先通过接口请求一次当前天气状况 let res = await this.$Http.getWeather({}); if(res.code === 200) { // 这里将接口获取到的天气数据放入 data 中的 weather 中即可 ... // 然后打开 websocket 实时接收 this.connectWebSocket(); } }, // websocket connectWebSocket (){ let _this = this; if ("WebSocket" in window) { console.log("浏览器支持 WebSocket!"); // 打开一个 webSocket let url ='xxxxxxxxxxx'; // 给你提供数据推送的地址 let ws = new webSocket(`ws://${url}`); // 连接成功 ws.onopen = function () { // Web Socket 已连接上,使用 send() 方法发送数据 ws.send("这是发送的测试数据"); console.log('连接成功'); }; // 接收数据处理 ws.onmessage = function (evt) { let received_msg = evt.data; // 这里将天气数据放入 data,然后天气就更新了 ... }; // 连接报错 ws.onerror = function () { console.log('连接报错...'); } // 连接关闭 ws.onclose = function () { // 关闭 websocket console.log("连接已关闭..."); } } else { // 浏览器不支持 WebSocket console.log("您的浏览器不支持 WebSocket!"); } }, }, mounted() { // 获取当地天气 this.getTheWeather(); } }
天气图片信息最好跟后端商量好天气code值,这样直接取值替换就完事了。
this.weather.url = require(`@/assets/img/weather/${weatherInfo.weatherCode}@2x.jpg" alt="vue使用websocket的详细步骤(vue使用webSocket更新实时天气的方法)" border="0" />
最后,介绍一种重连机制。
简单的重连机制,直接使用 setTimeout 即可。在连接报错/连接关闭时,使用定时器定时去重新执行 connectWebSocket 方法来重连即可。但是如此操作可能会存在多个问题,因此找到一种更加优雅的插件来重连——ReconnectingWebSocket。
ReconnectingWebSocket 其实就是封装的一个带有重连机制的 webSocketTest 实例,当连接断开时,会以一种友好的方式来尝试重新连接,直到连上为止。使用方法也比较简单,直接引入然后创建即可:
// 引入 import ReconnectingWebSocket from '@/util/ReconnectingWebSocket'; export default { data() { return { ... } }, methods: { ... connectWebSocket() { let _this = this; if ("WebSocket" in window) { console.log("浏览器支持 WebSocket!"); // 打开一个 webSocket let url ='xxxxxxxxxxx'; // 给你提供数据推送的地址 - let ws = new webSocket(`ws://${url}`); // 扔掉 + let ws = new ReconnectingWebSocket(`ws://${url}`); // 改成这样 // 连接成功 ws.onopen = function () { // Web Socket 已连接上,使用 send() 方法发送数据 ws.send("这是发送的测试数据"); console.log('连接成功'); }; // 接收数据处理 ws.onmessage = function (evt) { ... }; // 连接报错 ws.onerror = function () { console.log('连接报错...'); } // 连接关闭 ws.onclose = function () { // 关闭 websocket console.log("连接已关闭..."); } } else { // 浏览器不支持 WebSocket console.log("您的浏览器不支持 WebSocket!"); } } } }
ReconnectingWebSocket 是单个的JS文件,网上搜索即可。
到此这篇关于vue使用webSocket更新实时天气的方法的文章就介绍到这了,更多相关vue webSocket更新实时天气内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- vue实现商品详情讲解(京东 Vue3 组件库支持小程序开发的详细流程)
- vue如何在tab标签页循环加定时器(vue实现tab标签标签超出自动滚动)
- vue3 响应式的实现过程(Vue3.x使用mitt.js进行组件通信)
- vue设置属性没响应(Vue.$set 失效的坑 问题发现及解决方案)
- vue找不到水印设置(Vue使用自定义指令实现页面底部加水印)
- vue封装组件技巧(浅谈vue中所有的封装方式总结)
- vue是怎样进行页面跳转(Vue实现登陆跳转)
- vue定时器中间变颜色(Vue如何优雅的清除定时器)
- vue动态列表布局(vue项目实现左滑删除功能完整代码)
- vue怎么操作表格(如何在在Vue3中使用markdown 编辑器组件)
- vue请求token无效(关于Vue 消除Token过期时刷新页面的重复提示问题)
- vue实现双向绑定原理(vue实现双向数据绑定)
- vue中router的具体用法(vue-router中hash模式与history模式的区别)
- vue3 动态生成组件(如何在vue3.0+中使用tinymce及实现多图上传文件上传公式编辑功能)
- vueelementui动态表格(Vue Element前端应用开发之常规的JS处理函数)
- vue如何excel表格上传功能(Vue + iView实现Excel上传功能的完整代码)
- 吴彦祖陈冠希 恩怨 ,失去曾让他流泪的女友,终遇走过18年真爱(吴彦祖陈冠希恩怨)
- 痴情男神 吴彦祖 与妻子恋爱8年,结婚10年,家庭幸福美满(痴情男神吴彦祖)
- 成功破圈,小牛电动SQi强势开 跨(小牛电动SQi强势开)
- 挑战新国标电自天花板,九号机械师MMAX 110P深度体验(挑战新国标电自天花板)
- 《满江红》不要只当电影看,学生应该这样做(满江红不要只当电影看)
- 电影《民间怪谈录之走阴人》定档8月5日,开启一场中式惊悚之旅(电影民间怪谈录之走阴人定档8月5日)
热门推荐
- python3.9.6生成的注册表(厉害了,Python也能操作注册表)
- uiapp入门(amaze ui 的使用详细教程)
- HTML中h1到h6标签
- 如何看idea连接mysql数据库(IDEA 链接Mysql数据库并执行查询操作的完整代码)
- dedecms手机页面怎么固定(织梦dedecms配置手机wap站点并绑定二级域名)
- sqlserver的图形表(SQL Server纵表与横表相互转换的方法)
- python进度条怎么实现(Python小进度条显示代码)
- mysql8.0.21的安装步骤(mysql8.0.23 msi安装超详细教程)
- SQL SERVER中根据身份证号获取出生日期
- 远程桌面连接不上华为云服务器(华为云服务器远程桌面怎样实现复制粘贴?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9