成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

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

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

關(guān)于 webSocket 的操作及示例:

1.webSocket 連接

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

2.接收數(shù)據(jù)

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

3.重連機制

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

webSocket1.關(guān)于 webSocket

webSocket 是 HTML5 開始提供的一種在單個 TCP 連接上進行全雙工通訊的協(xié)議。瀏覽器通過 JavaScript 向服務(wù)器發(fā)出建立 webSocket 連接的請求,連接建立以后,客戶端和服務(wù)器端就可以通過 TCP 連接直接交換數(shù)據(jù)。

當你獲取 Web Socket 連接后,你可以通過 send() 方法來向服務(wù)器發(fā)送數(shù)據(jù),并通過 onmessage 事件來接收服務(wù)器返回的數(shù)據(jù)。

var Socket = new webSocket(url, [protocol] );

protocol 是可選的,指定了可接受的子協(xié)議

2.與 AJAX 輪的區(qū)別

現(xiàn)在,很多網(wǎng)站為了實現(xiàn)推送技術(shù),所用的技術(shù)都是 Ajax 輪詢。輪詢是在特定的的時間間隔(如每1秒),由瀏覽器對服務(wù)器發(fā)出HTTP請求,然后由服務(wù)器返回最新的數(shù)據(jù)給客戶端的瀏覽器。 這種傳統(tǒng)的模式帶來很 明顯的缺點,即瀏覽器需要不斷的向服務(wù)器發(fā)出請求,然而HTTP請求可能包含較長的頭部,其中真正有效的數(shù)據(jù)可能只是很小的一部分,顯然這樣會浪費很多的帶寬等資源。

HTML5 定義的 webSocket 協(xié)議,能更好的節(jié)省服務(wù)器資源和帶寬,并且能夠更實時地進行通訊。

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

3.webSocket 事件

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

4. 一個簡單的示例

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

function webSocketTest() { if ('webSocket' in window){alert('您的瀏覽器支持 webSocket!');// 打開一個 webSocketvar ws = new webSocket('ws://localhost:8080/test');ws.onopen = function() { // webSocket 已連接上,使用 send() 方法發(fā)送數(shù)據(jù) ws.send('發(fā)送數(shù)據(jù)'); console.log('數(shù)據(jù)發(fā)送中...');};ws.onmessage = function (evt) { // 接收到的數(shù)據(jù) var data = evt.data; console.log('數(shù)據(jù)已接收...');};ws.onerror = function () { // 連接報錯 console.log(’連接報錯...’);}ws.onclose = function() { // 關(guān)閉 webSocket console.log('連接已關(guān)閉...'); }; } else {// 瀏覽器不支持 webSocketalert('您的瀏覽器不支持 webSocket!'); }}

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

1.判斷瀏覽器是否支持 webSocket;2.創(chuàng)建一個 webSocket 實例;3.羅列 webSocket 事件并在相應(yīng)事件中處理相應(yīng)業(yè)務(wù)即可。

在vue中使用方法一樣

天氣更新

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

基礎(chǔ)代碼

<!-- 布局 使用的element,直接使用即可 --><el-popoverplacement='bottom':title='weather.title'trigger='hover':content='weather.cont'> <div slot='reference' class='weather'><img :src='http://www.piao2010.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) { // 這里將接口獲取到的天氣數(shù)據(jù)放入 data 中的 weather 中即可 ... // 然后打開 websocket 實時接收 this.connectWebSocket();} }, // websocket connectWebSocket (){let _this = this;if ('WebSocket' in window) { console.log('瀏覽器支持 WebSocket!'); // 打開一個 webSocket let url =’xxxxxxxxxxx’; // 給你提供數(shù)據(jù)推送的地址 let ws = new webSocket(`ws://${url}`); // 連接成功 ws.onopen = function () {// Web Socket 已連接上,使用 send() 方法發(fā)送數(shù)據(jù)ws.send('這是發(fā)送的測試數(shù)據(jù)');console.log(’連接成功’); }; // 接收數(shù)據(jù)處理 ws.onmessage = function (evt) {let received_msg = evt.data;// 這里將天氣數(shù)據(jù)放入 data,然后天氣就更新了... }; // 連接報錯 ws.onerror = function () {console.log(’連接報錯...’); } // 連接關(guān)閉 ws.onclose = function () {// 關(guān)閉 websocketconsole.log('連接已關(guān)閉...'); }} else { // 瀏覽器不支持 WebSocket console.log('您的瀏覽器不支持 WebSocket!');} },},mounted() { // 獲取當?shù)靥鞖? this.getTheWeather();} }圖片素材

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

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

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

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

簡單的重連機制,直接使用 setTimeout 即可。在連接報錯/連接關(guān)閉時,使用定時器定時去重新執(zhí)行 connectWebSocket 方法來重連即可。但是如此操作可能會存在多個問題,因此找到一種更加優(yōu)雅的插件來重連——ReconnectingWebSocket。

ReconnectingWebSocket 其實就是封裝的一個帶有重連機制的 webSocketTest 實例,當連接斷開時,會以一種友好的方式來嘗試重新連接,直到連上為止。使用方法也比較簡單,直接引入然后創(chuàng)建即可:

// 引入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’; // 給你提供數(shù)據(jù)推送的地址- let ws = new webSocket(`ws://${url}`); // 扔掉+ let ws = new ReconnectingWebSocket(`ws://${url}`); // 改成這樣 // 連接成功 ws.onopen = function () {// Web Socket 已連接上,使用 send() 方法發(fā)送數(shù)據(jù)ws.send('這是發(fā)送的測試數(shù)據(jù)');console.log(’連接成功’); }; // 接收數(shù)據(jù)處理 ws.onmessage = function (evt) {... }; // 連接報錯 ws.onerror = function () {console.log(’連接報錯...’); } // 連接關(guān)閉 ws.onclose = function () {// 關(guān)閉 websocketconsole.log('連接已關(guān)閉...'); }} else { // 瀏覽器不支持 WebSocket console.log('您的瀏覽器不支持 WebSocket!');}} }}

ReconnectingWebSocket 是單個的JS文件,網(wǎng)上搜索即可。

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

標簽: Vue
相關(guān)文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
制服丝袜激情欧洲亚洲| 1000部国产精品成人观看| 久久精品一二三区| 国产精品久久久免费| 亚洲18影院在线观看| 亚洲人午夜精品天堂一二香蕉| 久久久久九九九| 美女久久网站| 色综合久久精品| 色素色在线综合| 在线精品视频一区二区三四| 色婷婷狠狠综合| 在线观看国产日韩| 亚洲精品视频啊美女在线直播| 久久97超碰色| 国产精品自拍网站| 不卡av在线网| 午夜精品久久久久99热蜜桃导演| 精品在线播放午夜| 国产电影精品久久禁18| 国产91精品一区二区麻豆网站| 亚洲二区在线观看| 日韩av中文在线观看| 亚洲精品成人悠悠色影视| 欧美一区二区三区免费视频| 久久先锋影音| 欧美区在线观看| 精品国产麻豆免费人成网站| 欧美激情在线观看视频免费| 亚洲欧洲制服丝袜| 日韩av午夜在线观看| 国产一区二区三区在线观看免费| 亚洲高清免费在线| 亚洲免费观看在线视频| 国产精品情趣视频| 亚洲h在线观看| 一区二区三区四区国产精品| 亚洲第一福利一区| 国产精品中文有码| 韩国欧美一区| 在线看国产日韩| 欧美经典一区二区三区| 伊人色综合久久天天人手人婷| 亚洲欧洲av色图| 日韩—二三区免费观看av| 波多野结衣亚洲| 国产嫩草一区二区三区在线观看| 国产精品v亚洲精品v日韩精品 | 美女爽到高潮91| 成人美女在线观看| 成人性生交大片免费| 国产一区白浆| 精品免费一区二区三区| 亚洲一区二区精品视频| 亚洲国产日韩一区二区| 成人免费视频app| 国产亚洲精品bv在线观看| 欧美一区二区三区在线视频| 欧美人妖巨大在线| 一区二区三区四区激情| 懂色av噜噜一区二区三区av| 北岛玲一区二区三区四区| 久久综合狠狠| 国产精品丝袜黑色高跟| 国产激情91久久精品导航| 国产精品入口| 国产午夜亚洲精品午夜鲁丝片| 国产性色一区二区| 久久精品国产亚洲高清剧情介绍 | 一二三区精品福利视频| 丁香婷婷深情五月亚洲| 欧洲av在线精品| 日韩精品最新网址| 国产午夜精品美女毛片视频| 日韩成人一级片| 亚洲一区二区三区精品动漫| 久久综合成人精品亚洲另类欧美| 国产精品久久久久影院| 国产福利一区二区三区视频| 99久久国产免费看| 亚洲精品女人| 欧美国产禁国产网站cc| 国产一区91精品张津瑜| 91丨九色porny丨蝌蚪| 欧美放荡的少妇| 免费高清在线视频一区·| 中文有码久久| 亚洲精品免费一二三区| 一区国产精品| 国产精品家庭影院| 日本aⅴ亚洲精品中文乱码| 国产欧美一区二区色老头| 亚洲国产成人在线| 欧美fxxxxxx另类| 欧美精品一区二区高清在线观看| 亚洲色图一区二区| 韩国久久久久| 国产精品蜜臀在线观看| 欧美日韩午夜| 国产亚洲一区二区三区| 91在线一区二区三区| 精品久久五月天| av一本久道久久综合久久鬼色| 国产精品入口66mio| 欧美一级xxx| 国产成人午夜精品5599| 91麻豆精品国产无毒不卡在线观看| 成人免费在线观看入口| 国产一区二区三区四区hd| 国产精品视频看| 亚洲人成网站在线观看播放| 中文字幕在线一区免费| 国产999精品久久久久久绿帽| 在线观看的日韩av| 中文字幕视频一区二区三区久| 久久99国产精品久久99果冻传媒| 亚洲成色精品| 亚洲一区二区在线视频| 裸体一区二区| 麻豆国产一区二区| 国产精品免费在线| 午夜电影网一区| 欧美日韩在线播| 亚洲福利国产精品| 欧美日韩综合一区| 成人激情免费网站| 国产精品―色哟哟| 国产伦精品一区二区三| 国产精品色在线| 性8sex亚洲区入口| 亚洲欧洲三级电影| 一本色道a无线码一区v| 亚洲视频免费在线观看| 羞羞视频在线观看欧美| 久久不见久久见中文字幕免费| 亚洲欧美卡通另类91av| 久久超级碰视频| 欧美激情一区在线| 久久国产欧美| 粉嫩嫩av羞羞动漫久久久| 国产精品沙发午睡系列990531| k8久久久一区二区三区| 日韩一区二区不卡| 狠狠综合久久| 国产精品久久久久久户外露出| 91热门视频在线观看| 亚洲一区二区三区三| 337p亚洲精品色噜噜狠狠| 欧美午夜视频| 极品少妇xxxx精品少妇偷拍| 欧美性色欧美a在线播放| 免费久久精品视频| 国产精品女同一区二区三区| 色婷婷亚洲精品| 欧美sm重口味系列视频在线观看| 国产午夜精品一区二区三区视频| 欧美1级日本1级| 青青草国产精品97视觉盛宴| 国产婷婷一区二区| 黑人中文字幕一区二区三区| 久久精品av麻豆的观看方式| 国产亚洲短视频| 欧美群妇大交群中文字幕| 国产高清在线精品| 亚洲自拍偷拍麻豆| 国产亚洲一区二区三区四区| 一本色道综合亚洲| 黄色国产精品| 亚洲国产一二三| 欧美日韩综合在线免费观看| 在线看片一区| 偷拍一区二区三区| 国产视频一区二区在线观看| 欧美日韩亚洲综合| 国产精品一区二区三区四区五区 | 丝袜a∨在线一区二区三区不卡| 日本精品裸体写真集在线观看 | 国产精品免费一区二区三区观看| 日韩av在线发布| 欧美一区二区免费视频| 嫩草成人www欧美| 亚洲一级网站| 91在线免费看| 成人午夜又粗又硬又大| 久久se精品一区二区| 亚洲成人午夜影院| 亚洲视频每日更新| 国产精品午夜电影| 精品伦理精品一区| 国产一区91| 亚洲黄色三级| 极品av少妇一区二区| 美腿丝袜亚洲综合| 日韩福利电影在线| 国产亚洲欧洲997久久综合| 日韩一区二区视频在线观看| 欧美日韩黄色影视| 亚洲激情欧美| 亚洲国产专区| 国产福利一区二区三区视频 |