日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

vue使用webSocket更新實時天氣的方法

瀏覽:126日期:2022-09-28 17:59:09
目錄前言關于 webSocket 的操作及示例:webSocket1.關于 webSocket2.與 AJAX 輪的區別3.webSocket 事件4. 一個簡單的示例天氣更新圖片素材重連機制前言

在 vue 中使用 webSocket 做一個簡單的天氣實時更新模塊。

vue使用webSocket更新實時天氣的方法

關于 webSocket 的操作及示例:

1.webSocket 連接

vue使用webSocket更新實時天氣的方法

2.接收數據

vue使用webSocket更新實時天氣的方法

3.重連機制

vue使用webSocket更新實時天氣的方法

webSocket1.關于 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 協議,能更好的節省服務器資源和帶寬,并且能夠更實時地進行通訊。

vue使用webSocket更新實時天氣的方法

3.webSocket 事件

vue使用webSocket更新實時天氣的方法

4. 一個簡單的示例

通過上述簡單介紹,我們來創建一個 webSocket 實例試一下:

function webSocketTest() { if ('webSocket' in window){alert('您的瀏覽器支持 webSocket!');// 打開一個 webSocketvar 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 {// 瀏覽器不支持 webSocketalert('您的瀏覽器不支持 webSocket!'); }}

可以看出,其實 webSocket 使用方法很簡單:

1.判斷瀏覽器是否支持 webSocket;2.創建一個 webSocket 實例;3.羅列 webSocket 事件并在相應事件中處理相應業務即可。

在vue中使用方法一樣

天氣更新

此處展示一下前面說過的天氣實時更新效果實現。項目框架為 vueelement。

基礎代碼

<!-- 布局 使用的element,直接使用即可 --><el-popoverplacement='bottom':title='weather.title'trigger='hover':content='weather.cont'> <div slot='reference' class='weather'><img :src='http://www.b3g6.com/bcjs/weather.url' alt=''> </div></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 () {// 關閉 websocketconsole.log('連接已關閉...'); }} else { // 瀏覽器不支持 WebSocket console.log('您的瀏覽器不支持 WebSocket!');} },},mounted() { // 獲取當地天氣 this.getTheWeather();} }圖片素材

天氣圖片信息最好跟后端商量好天氣code值,這樣直接取值替換就完事了。

vue使用webSocket更新實時天氣的方法

this.weather.url = require(`@/assets/img/weather/${weatherInfo.weatherCode}@2x.png`);重連機制

最后,介紹一種重連機制。

簡單的重連機制,直接使用 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 () {// 關閉 websocketconsole.log('連接已關閉...'); }} else { // 瀏覽器不支持 WebSocket console.log('您的瀏覽器不支持 WebSocket!');}} }}

ReconnectingWebSocket 是單個的JS文件,網上搜索即可。

到此這篇關于vue使用webSocket更新實時天氣的方法的文章就介紹到這了,更多相關vue webSocket更新實時天氣內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲精品一级| 免费看的黄色欧美网站 | 免费视频一区三区| 久久国际精品| 成人羞羞视频播放网站| 欧美黄色网页| 亚洲精品影视| 三上悠亚国产精品一区二区三区| 久久国产日本精品| 丝袜美腿一区二区三区| 视频在线观看91| 99国产精品久久久久久久| 久久国产精品成人免费观看的软件| 91精品尤物| 亚洲免费激情| 国产精品av久久久久久麻豆网| 91看片一区| 91亚洲人成网污www| 欧美极品中文字幕| 久久国产精品免费精品3p| 日本在线精品| 欧美aa在线视频| 天堂久久av| 一区在线免费观看| 日韩精品电影| 精品国产一区二区三区噜噜噜| 夜夜精品视频| 亚洲一区日韩在线| 亚洲欧美日本国产| 国产乱人伦丫前精品视频| 国产精品久久久久久模特 | 国精品产品一区| 一区二区高清| 亚洲在线成人| 国产精品久久国产愉拍| 精品中文一区| 成人一二三区| 精品一区二区三区在线观看视频| 亚洲伊人精品酒店| 亚洲调教视频在线观看| 国产一区二区三区亚洲| 久久亚洲国产精品一区二区| 久久精品国产亚洲夜色av网站 | 蜜桃视频在线观看一区二区| 日韩欧美精品一区| 日韩精品一区二区三区av | 亚洲美洲欧洲综合国产一区| 免费美女久久99| 欧美大黑bbbbbbbbb在线| 欧美天堂视频| 亚洲欧美激情诱惑| 三级在线观看一区二区| 午夜欧美在线| 亚洲精品高潮| 国产精品欧美日韩一区| 一级欧美视频| 国产精品亚洲四区在线观看| 色爱av综合网| 奇米狠狠一区二区三区| 国产精品高颜值在线观看| 视频一区视频二区在线观看| 国产亚洲第一伦理第一区| 国产在线观看www| 国产视频一区免费看| 亚洲精品一二| 老司机精品视频网| 婷婷综合六月| 精品三级在线观看视频| 九色精品91| 国产精区一区二区| 久久亚洲资源中文字| 99久久亚洲精品| 精品国产三区在线| 欧美在线精品一区| 午夜在线精品偷拍| 国产精品精品国产一区二区| 日韩av二区在线播放| 亚洲精品国产偷自在线观看| 久久精品国产精品亚洲毛片| 午夜精品久久久久久久久久蜜桃| 日韩精品中文字幕一区二区| 国产精品亚洲欧美| 精品在线播放| 亚洲电影在线| 在线综合视频| 国产欧美在线| 日韩精品欧美激情一区二区| 亚洲在线观看| 久久国产乱子精品免费女| 妖精视频成人观看www| 欧美影院三区| 久久国产精品亚洲77777| 亚洲欧美在线专区| 麻豆精品久久| 精品日韩一区| 欧美一区免费| 久久国内精品视频| 97视频热人人精品免费| 午夜电影亚洲| 国产精品草草| 蜜桃视频一区二区三区在线观看| 日韩不卡在线观看日韩不卡视频| 在线看片福利| 日韩黄色在线观看| 午夜精品成人av| 欧美精品自拍| 99视频精品全国免费| 亚洲综合欧美| 国产美女亚洲精品7777| 日韩成人免费| 中文在线а√天堂| 香蕉人人精品| 免费视频一区三区| 欧美一区三区| 好吊视频一区二区三区四区| 九九99久久精品在免费线bt| 亚洲精品在线a| 亚洲国产一区二区三区在线播放| 午夜日韩av| 亚洲欧美日本国产专区一区| 日韩欧美一区二区三区在线视频| 国产亚洲永久域名| 成人亚洲一区二区| 欧美日韩免费观看视频| 免费日韩av片| 青草国产精品| 亚洲www免费| 中文日韩欧美| 日韩三级视频| 精品国产亚洲一区二区三区在线| 亚洲一区不卡| 久久精品二区三区| 日本在线高清| 999久久久国产精品| 欧美13videosex性极品| 国产aa精品| 欧美日韩99| 久久一二三区| 国产福利片在线观看| 91九色精品国产一区二区| 日韩精品一区二区三区免费观看| 婷婷激情图片久久| 国产精品一区2区3区| 91精品国产成人观看| 日韩欧美在线精品| 91精品一区二区三区综合在线爱 | 欧美午夜不卡| 欧美经典一区| 欧美日韩va| 亚洲激情二区| 蜜臀av一区二区在线免费观看| 午夜国产精品视频免费体验区| 好看的av在线不卡观看| 国产一区二区精品| 亚洲精品乱码久久久久久蜜桃麻豆| 日韩一区二区三区精品| 国产美女亚洲精品7777| 天堂俺去俺来也www久久婷婷| 日本视频在线一区| 日韩欧美网址| 中文字幕av一区二区三区四区| 日韩精品一级| 午夜欧美巨大性欧美巨大| 在线精品视频一区| 国产日韩欧美一区| 五月婷婷亚洲| 久久激情五月婷婷| 久久中文精品| 免费人成黄页网站在线一区二区| 在线人成日本视频| 免费av一区二区三区四区| 影音先锋国产精品| 国产精品magnet| 日本午夜精品一区二区三区电影| 国产精品一区高清| 国产欧美91| 韩国三级一区| 中文无码久久精品| 精品视频91| 亚洲四虎影院| 国产精品视区| 久久成人福利| 国产精品伦一区二区| а√在线中文在线新版| 日韩一区二区免费看| 国产精品一区二区三区四区在线观看| 精品久久国产一区| 在线一区av| 亚洲免费中文| 99精品电影| 亚洲成人三区| 日韩黄色av| 激情五月综合网| 中文字幕系列一区| 亚洲综合国产| 樱桃视频成人在线观看| 蜜桃av一区| 欧美日本一区| 黑丝一区二区三区| 999国产精品视频|