vue使用websocket的方法实例分析


Posted in Javascript onJune 22, 2019

本文实例讲述了vue使用websocket的方法。分享给大家供大家参考,具体如下:

最近项目需要使用到websocket 但是框架是vue  网上查阅很多资料 vue-websocket 老是连接不上 索性就不适用封装的插件了,直接使用原生的websocket  我这边需求是 只需要接受就好 不需要发送 代码如下:

爬坑之路: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')
    } //连接成功建立的回调方法 websocket.onopen = function () { console.log("WebSocket连接成功")
    console.log(this)----------------------------------------------------------this指向websocket
  };
//接收到消息的回调方法
websocket.onmessage = function (event) {
console.log(this)
console.log(event);
 this.productinfos=JSON.parse(event.data);//websocket请求过来的是string 需要格式
 if(demo.offsetHeight<demo1.offsetHeight){//内部比外部高度大的时候滑动
this.upScroll()//这是this指向websocket 所以没有此方法 会报错
}
this.sliceArray() }
 }
 };
//连接关闭的回调方法 websocket.onclose = function () {
console.log("WebSocket连接关闭");
};
//连接发生错误的回调方法 websocket.onerror = function () {
console.log("WebSocket连接发生错误");
};
//监听窗口关闭事件,当窗口关闭时,主动去关闭websocket连接,防止连接还没断开就关闭窗口,server端会抛异常。
 window.onbeforeunload = function () {
websocket.close();
//关闭WebSocket连接 };
 },
sliceArray(){//截取数组的后四位 },
 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){ //数据接收
  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程序设计有所帮助。

Javascript 相关文章推荐
AlertBox 弹出层信息提示框效果实现步骤
Oct 11 Javascript
JS中的异常处理方法分享
Dec 22 Javascript
jquery 操作css样式、位置、尺寸方法汇总
Nov 28 Javascript
基于JQuery实现仿网易邮箱全屏动感滚动插件fullPage
Sep 20 Javascript
javascript-解决mongoose数据查询的异步操作
Dec 22 Javascript
BootStrap Table对前台页面表格的支持实例讲解
Dec 22 Javascript
Angular项目中$scope.$apply()方法的使用详解
Jul 26 Javascript
微信小程序tabBar 返回tabBar不刷新页面
Jul 25 Javascript
详解element-ui表格中勾选checkbox,高亮当前行
Sep 02 Javascript
解决echarts数据二次渲染不成功的问题
Jul 20 Javascript
Openlayers实现地图的基本操作
Sep 28 Javascript
JS实现简单的文字无缝上下滚动功能示例
Jun 22 #Javascript
js图片查看器插件用法示例
Jun 22 #Javascript
JS实现继承的几种常用方式示例
Jun 22 #Javascript
让 babel webpack vue 配置文件支持智能提示的方法
Jun 22 #Javascript
简单了解TypeScript中如何继承 Error 类
Jun 21 #Javascript
如何在JavaScript中谨慎使用代码注释
Jun 21 #Javascript
简单了解JavaScript中常见的反模式
Jun 21 #Javascript
You might like
使用PHP 5.0创建图形的巧妙方法
2010/10/12 PHP
php分页查询的简单实现代码
2017/03/14 PHP
PHP设计模式之策略模式原理与用法实例分析
2019/04/04 PHP
laravel5表单唯一验证的实例代码
2019/09/30 PHP
javascript支持firefox,ie7页面布局拖拽效果代码
2007/12/20 Javascript
JavaScript脚本性能优化注意事项
2008/11/18 Javascript
jQuery Flash/MP3/Video多媒体插件
2010/01/18 Javascript
jquery 简单应用示例总结
2013/08/09 Javascript
详解Matlab中 sort 函数用法
2016/03/20 Javascript
基于jQuery实现动态搜索显示功能
2016/05/05 Javascript
全面解析多种Bootstrap图片轮播效果
2016/05/27 Javascript
js仿小米官网图片轮播特效
2016/09/29 Javascript
利用jQuery对无序列表排序的简单方法
2016/10/16 Javascript
JavaScript易错知识点整理
2016/12/05 Javascript
js实现日历与定时器
2017/02/22 Javascript
利用nvm管理多个版本的node.js与npm详解
2017/11/02 Javascript
vue实现PC端录音功能的实例代码
2019/06/05 Javascript
浅谈一种让小程序支持JSX语法的新思路
2019/06/16 Javascript
微信小程序-API接口安全详解
2019/07/16 Javascript
JS事件流与事件处理程序实例分析
2019/08/16 Javascript
es6函数之箭头函数用法实例详解
2020/04/25 Javascript
Antd-vue Table组件添加Click事件,实现点击某行数据教程
2020/11/17 Javascript
Python基于Socket实现的简单聊天程序示例
2017/08/05 Python
python中hashlib模块用法示例
2017/10/30 Python
Python用csv写入文件_消除空余行的方法
2018/07/06 Python
用python对excel进行操作(读,写,修改)
2020/12/25 Python
html5文本内容_动力节点Java学院整理
2017/07/11 HTML / CSS
亿阳信通股份有限公司笔试题(C#)
2016/03/04 面试题
商务英语本科生的自我评价分享
2013/11/15 职场文书
信息技术专业个人自我评价
2013/12/11 职场文书
军训感想500字
2014/02/20 职场文书
意外伤害赔偿协议书
2014/09/16 职场文书
研究生论文答辩开场白
2015/05/27 职场文书
教师纪律作风整顿心得体会
2016/01/23 职场文书
如何使用CocosCreator对象池
2021/04/14 Javascript
python基础之匿名函数详解
2021/04/21 Python