vue + webSocket 實(shí)時(shí)任務(wù)信息通知【轉(zhuǎn)】

vue + webSocket 實(shí)時(shí)任務(wù)信息通知

websocket

WebSocket 協(xié)議在2008年誕生腰涧,2011年成為國(guó)際標(biāo)準(zhǔn)清焕。所有瀏覽器都已經(jīng)支持了罕模。
它的最大特點(diǎn)就是,服務(wù)器可以主動(dòng)向客戶端推送信息杈女,客戶端也可以主動(dòng)向服務(wù)器發(fā)送信息,是真正的雙向平等對(duì)話,屬于服務(wù)器推送技術(shù)的一種达椰。

特點(diǎn)

  • 建立在TCP協(xié)議之上翰蠢,服務(wù)端的實(shí)現(xiàn)比較容易;
  • 與HTTP協(xié)議有著良好的兼容性啰劲。默認(rèn)端口也是80和443梁沧,并且握手階段采用HTTP協(xié)議,因此握手時(shí)不容易屏蔽蝇裤,能通過各種HTTP代理服務(wù)器廷支;
  • 數(shù)據(jù)格式比較輕量,性能開銷小栓辜,通信高效恋拍;
  • 可以發(fā)送文本,也可以發(fā)送二進(jìn)制數(shù)據(jù)
  • 沒有同源限制藕甩,客戶端可以與任意服務(wù)器通信
  • 協(xié)議標(biāo)識(shí)符是 WS(如果加密施敢,則為WSS),服務(wù)器網(wǎng)址就是URL
image
VUE + WebSocket 長(zhǎng)鏈接實(shí)現(xiàn)

在項(xiàng)目的創(chuàng)建 utils/websocket.js

<!--引入store狭莱,用于管理socket推送來的消息-->
import store from '../store'
<!--封裝websocket對(duì)象-->
const WS = {
    $ws:null, // webscoket實(shí)例
    wsUrl: 'ws://xxxxx.com:80/xxx', // websocket鏈接地址
    <!--初始化webSocket-->
    createWS:function(){
        if('WebSocket' in window){
            this.$ws = new WebSocket(wsURl)
            this.$ws.onopen = this.wsOpen
            this.$ws.onmessage = this.wsMessage
            this.$ws.onerror = this.wsError
            this.$ws.onclose = this.wsClose
        } else {
            alert('當(dāng)前瀏覽器不支持webSocket')
        }
    },
    <!--webSocket 打開-->
    wsOpen: function() {
        this.$ws.send('連接成功')
        console.log('== websocket open ==')
        <!--開始心跳-->
        heartBeat.start()
    },
    <!--websocket 接收到服務(wù)器消息-->
    wsMessage:function(msg) {
        console.log('== websocket message ==', msg)
        <!--接受到消息僵娃,重置心跳-->
        heartBeat.reset()
        store.commit('SET_WS_MSG', msg.data)
    },
    <!--websocket 發(fā)生錯(cuò)誤-->
    wsError: function(err){
        console.log('== websocket error ==', err)
    },
    <!--websocket 關(guān)閉連接-->
    wsClose: function(event){
        console.log('== websocket close ==', event)
    }
}
<!--webSocket 心跳-->
const heartBeat = {
    timeout:30000, // 心跳重連時(shí)間
    timeoutObj:null, // 定時(shí)器
    reset:function(){
        clearInterVal(this.timeoutObj)
        console.log('websocket 心跳')
        WS.start()
    },
    start:function(){
        this.timeoutObj = setTimeout(function(){
            if(WS.$ws.readyState === 1){
                WS.$ws.send('HeartBeat')
            }
        },this.timeout)
    }
}
export default WS

在main.js中引入WS,掛載到Vue原型上

    import Vue from 'vue'
    import WS from '@/util/websocket'
    Vue.prototype.$ws = WS

在store/index.js創(chuàng)建全局?jǐn)?shù)據(jù)存儲(chǔ)

    const store= new Vuex.Store({
        state:{
            webSocketMsg:''
        },
        mutations:{
            SET_WS_MSG (state, msg) =>{
                state.webSocketMsg = msg
            }
        }
    })

在單個(gè)組件內(nèi)部使用

    computed:{
        getWsMsg (){
            return this.$store.state.webSocketMsg
        }
    },
    watch:{
        getWsMsg:{
            handler: function(newVal) {
                console.log(newVal)
                alert('接收到webSocket推送'+ newVal)
            }
        }
    }

如果要在所有的界面都能接收socket推送消息贩毕,并彈出提示可以在布局組件(Layout.vue ...)中監(jiān)聽

    computed:{
        getWsMsg (){
            return this.$store.state.webSocketMsg
        }
    },
    watch:{
        getWsMsg:{
            handler: function(newVal) {
                console.log(newVal)
                alert('接收到webSocket推送'+ newVal)
            }
        }
    }

參考文檔

作者:Beppo
鏈接:http://www.reibang.com/p/fe8bd81814b0
來源:簡(jiǎn)書

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末悯许,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子辉阶,更是在濱河造成了極大的恐慌先壕,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谆甜,死亡現(xiàn)場(chǎng)離奇詭異垃僚,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)规辱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門谆棺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人罕袋,你說我怎么就攤上這事改淑。” “怎么了浴讯?”我有些...
    開封第一講書人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵朵夏,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我榆纽,道長(zhǎng)仰猖,這世上最難降的妖魔是什么捏肢? 我笑而不...
    開封第一講書人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮饥侵,結(jié)果婚禮上鸵赫,老公的妹妹穿的比我還像新娘。我一直安慰自己躏升,他們只是感情好辩棒,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著膨疏,像睡著了一般盗温。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上成肘,一...
    開封第一講書人閱讀 52,268評(píng)論 1 309
  • 那天,我揣著相機(jī)與錄音斧蜕,去河邊找鬼双霍。 笑死,一個(gè)胖子當(dāng)著我的面吹牛批销,可吹牛的內(nèi)容都是我干的洒闸。 我是一名探鬼主播,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼均芽,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼丘逸!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起掀宋,我...
    開封第一講書人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤深纲,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后劲妙,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體湃鹊,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年镣奋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了币呵。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡侨颈,死狀恐怖余赢,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情哈垢,我是刑警寧澤妻柒,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站温赔,受9級(jí)特大地震影響蛤奢,放射性物質(zhì)發(fā)生泄漏鬼癣。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一啤贩、第九天 我趴在偏房一處隱蔽的房頂上張望待秃。 院中可真熱鬧,春花似錦痹屹、人聲如沸章郁。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽暖庄。三九已至,卻和暖如春楼肪,著一層夾襖步出監(jiān)牢的瞬間培廓,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工春叫, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留肩钠,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓暂殖,卻偏偏與公主長(zhǎng)得像价匠,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子呛每,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359