本文實例講述了vue使用websocket的方法。分享給大家供大家參考,具體如下:
成都創(chuàng)新互聯(lián)公司一直通過網(wǎng)站建設和網(wǎng)站營銷幫助企業(yè)獲得更多客戶資源。 以"深度挖掘,量身打造,注重實效"的一站式服務,以成都網(wǎng)站設計、做網(wǎng)站、成都外貿(mào)網(wǎng)站建設公司、移動互聯(lián)產(chǎn)品、營銷型網(wǎng)站建設服務為核心業(yè)務。十多年網(wǎng)站制作的經(jīng)驗,使用新網(wǎng)站建設技術,全新開發(fā)出的標準網(wǎng)站,不但價格便宜而且實用、靈活,特別適合中小公司網(wǎng)站制作。網(wǎng)站管理系統(tǒng)簡單易用,維護方便,您可以完全操作網(wǎng)站資料,是中小公司快速網(wǎng)站建設的選擇。
最近項目需要使用到websocket 但是框架是vue 網(wǎng)上查閱很多資料 vue-websocket 老是連接不上 索性就不適用封裝的插件了,直接使用原生的websocket 我這邊需求是 只需要接受就好 不需要發(fā)送 代碼如下:
爬坑之路:vue里面this指向問題
第一版 使用原生js
mounted(){ console.log(this)----------------------------------------------------------this指向vue this.initWebpack(); }, methods: { initWebpack() { let websocket = ''; if ('WebSocket' in window) { websocket = new WebSocket("ws://192.168.1.99:8080/tv/websocket"); } else { alert('當前瀏覽器 Not support websocket') } //連接成功建立的回調(diào)方法 websocket.onopen = function () { console.log("WebSocket連接成功") console.log(this)----------------------------------------------------------this指向websocket }; //接收到消息的回調(diào)方法 websocket.onmessage = function (event) { console.log(this) console.log(event); this.productinfos=JSON.parse(event.data);//websocket請求過來的是string 需要格式 if(demo.offsetHeight<demo1.offsetHeight){//內(nèi)部比外部高度大的時候滑動 this.upScroll()//這是this指向websocket 所以沒有此方法 會報錯 } this.sliceArray() } } }; //連接關閉的回調(diào)方法 websocket.onclose = function () { console.log("WebSocket連接關閉"); }; //連接發(fā)生錯誤的回調(diào)方法 websocket.onerror = function () { console.log("WebSocket連接發(fā)生錯誤"); }; //監(jiān)聽窗口關閉事件,當窗口關閉時,主動去關閉websocket連接,防止連接還沒斷開就關閉窗口,server端會拋異常。 window.onbeforeunload = function () { websocket.close(); //關閉WebSocket連接 }; }, sliceArray(){//截取數(shù)組的后四位 }, upScroll(){ }, }
第二版:正解
methods:{ initWebpack(){//初始化websocket const wsuri = "ws地址"; this.websock = new WebSocket(wsuri);//這里面的this都指向vue this.websock.onopen = this.websocketopen; this.websock.onmessage = this.websocketonmessage; this.websock.onclose = this.websocketclose; this.websock.onerror = this.websocketerror; }, websocketopen(){//打開 console.log("WebSocket連接成功") }, websocketonmessage(e){ //數(shù)據(jù)接收 console.log(e) this.productinfos = JSON.parse(e.data); }, websocketclose(){ //關閉 console.log("WebSocket關閉"); }, websocketerror(){ //失敗 console.log("WebSocket連接失敗"); }, }
this.websock.onopen
的 this指向的是websocket 如果想要給vue里面的data里面的變量賦值 就需要 this
指向vue 所以需要對websocket的方法賦值
希望本文所述對大家vue.js程序設計有所幫助。
分享題目:vue使用websocket的方法實例分析
網(wǎng)頁網(wǎng)址:http://www.chinadenli.net/article44/jcoche.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、App開發(fā)、品牌網(wǎng)站制作、做網(wǎng)站、微信公眾號、移動網(wǎng)站建設
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)