uniapp使用WebSocket uniapp使用WebSocket Uniapp整合WebSocket uniapp使用 websocket
uniapp使用WebSocket uniapp使用WebSocket Uniapp整合WebSocket uniapp使用 websocket
- 前言
- 1、Socket.js
- 2、main.js引入
- 3、组件中调用
前言
代码中的示例只在 H5、APP环境下成功运行,小程序环境下如果无效,需要使用预编译 - 条件性的编译,适配 小程序环境
// #ifdef MP-WEIXIN
// #endif
Uni-app 支持多种预编译指令,包括但不限于:
#ifdef H5:针对 Web H5页面。#ifdef APP-PLUS:针对原生应用(Android 和 iOS)。#ifdef MP-WEIXIN:针对微信小程序。#ifdef MP-ALIPAY:针对支付宝小程序。#ifdef MP-Baidu:针对百度小程序。#ifdef MP-Toutiao:针对字节跳动小程序。#ifdef MP-QQ:针对 QQ 小程序。#ifdef MP-Kuaishou:针对快手小程序。#ifdef MP-JD:针对京东小程序。
1、Socket.js
// config.js 文件位于 uniapp根目录全局文件,如果没有,则固定将socket地址手动写死
import config from '@/config'const socketUrl = config.baseSocketUrl// 重试最大次数, 避免出现网络错误停留在页面 出现无限socket重连导致 浏览器卡死
const retryMaxTimes = 10let retryTimes = 1class WebSocketClass {constructor() {this.lockReconnect = false; // 是否开始重连this.wsUrl = ""; // ws 地址// this.globalCallback = this.globalCallback(); // 回调方法this.userClose = false; // 是否主动关闭this.createWebSocket(socketUrl);}createWebSocket(url) {// #ifdef H5if (typeof(WebSocket) === 'undefined') {this.writeToScreen("您的浏览器不支持WebSocket,无法获取数据");return false}// #endif// #ifdef APP-PLUSif (typeof(uni.connectSocket) === 'undefined') {this.writeToScreen("您的浏览器不支持WebSocket,无法获取数据");return false}// #endifthis.wsUrl = url;try {// 创建一个this.ws对象【发送、接收、关闭socket都由这个对象操作】// #ifdef H5this.ws = new WebSocket(this.wsUrl);// 更改消息数据格式为 arraybufferthis.ws.binaryType = 'arraybuffer';this.initEventHandle();// #endif// #ifdef APP-PLUSthis.ws = uni.connectSocket({url: this.wsUrl,success(data) {console.log("websocket连接成功");// 更改消息数据格式为 arraybufferthis.ws.binaryType = 'arraybuffer';this.initEventHandle();},});// #endif} catch (e) {this.reconnect(url);}}// 初始化initEventHandle() {var _this = this_this.ws.binaryType = 'arraybuffer';console.info(_this)/*** 监听WebSocket连接打开成功*/// #ifdef H5_this.ws.onopen = (event) => {console.log("WebSocket连接打开");};// #endif// #ifdef APP-PLUS_this.ws.onOpen(res => {console.log('WebSocket连接打开');});// #endif/*** 连接关闭后的回调函数*/// #ifdef H5_this.ws.onclose = (event) => {if (!_this.userClose) {_this.reconnect(_this.wsUrl); //重连}};// #endif// #ifdef APP-PLUS_this.ws.onClose(() => {if (!_this.userClose) {_this.reconnect(_this.wsUrl); //重连}});// #endif/*** 报错时的回调函数*/// #ifdef H5_this.ws.onerror = (event) => {if (!_this.userClose) {_this.reconnect(_this.wsUrl); //重连}};// #endif// #ifdef APP-PLUS_this.ws.onError(() => {if (!_this.userClose) {_this.reconnect(_this.wsUrl); //重连}});// #endif/*** 收到服务器数据后的回调函数*/// #ifdef H5_this.ws.onmessage = (event) => {if (_this.isJSON(event.data)) {const jsonobject = JSON.parse(event.data)_this.globalCallback(jsonobject)} else {_this.globalCallback(event.data)}};// #endif// #ifdef APP-PLUS_this.ws.onMessage(event => {if (_this.isJSON(event.data)) {const jsonobject = JSON.parse(event.data)_this.globalCallback(jsonobject)} else {_this.globalCallback(event.data)}});// #endif}// 关闭ws连接回调reconnect(url) {if (this.lockReconnect) return;this.ws.close();this.lockReconnect = true; // 关闭重连,没连接上会一直重连,设置延迟避免请求过多if (retryTimes < retryMaxTimes) {retryTimes = retryTimes + 1console.info('WebSocket当前重试次数', retryTimes)setTimeout(() => {this.createWebSocket(url);this.lockReconnect = false;}, 1000);}else{console.info('WebSocket当前已经重试最大次数,依旧无法连接,不在重试,请检查网络是否正常')}}// 发送信息方法webSocketSendMsg(msg) {this.ws.send(JSON.stringify(msg));}// 获取ws返回的数据方法getWebSocketMsg(callback) {this.globalCallback = callback}globalCallback(data) {return new Promise((resolve, reject) => {resolve(data); // 成功时调用resolve});}// 关闭ws方法closeSocket() {if (this.ws) {this.userClose = true;this.ws.close({success(res) {console.log("关闭成功", res)},fail(err) {console.log("关闭失败", err)}});}}writeToScreen(massage) {console.log(massage);}isJSON(str) {if (typeof str == 'string') {try {var obj = JSON.parse(str);if (typeof obj == 'object' && obj) {return true;} else {return false;}} catch (e) {// console.log('error:'+str+'!!!'+e);return false;}}// console.log('It is not a string!')}
}
export default WebSocketClass;
2、main.js引入
import WS from "@/utils/socket.js"
const ws = new WS()Vue.prototype.$ws = wsconst app = new Vue({...App
})
3、组件中调用
export default {data() {return {}},mounted() {const _t = this// 发送消息_t.$ws.webSocketSendMsg({'msg': 'hello'})// 监听服务端发送的消息_t.$ws.getWebSocketMsg((res) => {console.info('接收消息', res)})}}相关文章:
uniapp使用WebSocket uniapp使用WebSocket Uniapp整合WebSocket uniapp使用 websocket
uniapp使用WebSocket uniapp使用WebSocket Uniapp整合WebSocket uniapp使用 websocket 前言1、Socket.js2、main.js引入3、组件中调用 前言 代码中的示例只在 H5、APP环境下成功运行,小程序环境下如果无效,需要使用预编译 - 条件性的编译,适…...
SSH Exporter:基于Prometheus的远程系统性能监控神器
SSH Exporter English | 中文 介绍 SSH Exporter 是一个基于 Prometheus 规范的监控工具,通过 SSH 协议远程收集目标服务器的系统性能数据,如 CPU 使用率、内存使用情况、磁盘和网络 I/O 等,并将这些数据暴露为 Prometheus 格式的 metrics…...
Docker基础概念
Docker 是一个流行的容器化平台,它使开发者能够打包他们的应用程序及其依赖项到一个轻量级、可移植的容器中。这有助于确保应用程序无论在哪里运行都能获得一致的结果。以下是 Docker 的几个基础概念的详细解释: 1. Docker 镜像 (Image) 定义: Docker …...
小白进阶为大神
编程已成为当代大学生的必备技能,但面对众多编程语言和学习资源,新生们常常感到迷茫。如何选择适合自己的编程语言?如何制定有效的学习计划?如何避免常见的学习陷阱?今天,我就来分享一下这方面的经验和知识…...
2024最新Python和PyCharm的安装教程
Python和PyCharm的安装教程如下: Python安装教程 一、下载Python安装包 访问Python官方网站:Welcome to Python.org。 点击页面上方的“Downloads”链接。 在下载页面,选择“Windows”系统(以Windows系统为例)&…...
数据库死锁:深入解析与应对策略
在数据库管理系统中,死锁是一个常见且棘手的问题,它可能导致系统性能下降、事务延迟甚至完全阻塞。本文将深入探讨数据库死锁的概念、产生原因、检测方法以及预防与解决策略,帮助读者更好地理解和应对这一挑战。 一、什么是数据库死锁&#…...
Python入门宝藏《看漫画学Python》,495页漫画带你弄清python知识点!简单易懂 | 附PDF全彩版
华为出品的《看漫画学Python》全彩PDF教程是一本适合Python初学者的学习资料,通过漫画的形式将复杂的Python技术问题简单化,使学习过程更加生动有趣。以下是对该教程的内容简介、本书概要及本书目录的详细解析: 内容简介 《看漫画学Python》…...
Webshell管理工具:AntSword(中国蚁剑)
中国蚁剑是一款开源的跨平台网站管理工具,它主要面向于合法授权的渗透测试安全人员以及进行常规操作的网站管理员。 通俗的讲:中国蚁剑是 一 款比菜刀还牛的shell控制端软件。 一、中国蚁剑下载 1. 下载 AntSword-Loader https://github.com/AntSwordP…...
Java 中的File类
路径分为绝对路径和相对路径。 相对路径肯定是相对谁来说的,一般是一个文件相对于另外一个文件而言的路径。 下面是一个例子,比如index.htm如何找到photo.jpg呢? c:/website/web/index.htmc:/website/img/photo.jpg 所以在index.htm中使用…...
java将map转json字符串或者再将json字符串转回map,java将对象转json字符串或者互想转换,对象集合和json字符串互转
1.导入hutool工具依赖 <dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.16</version></dependency>2.直接复制一下代码运行 import cn.hutool.json.JSONUtil;import java.util.Ar…...
数据库管理-第225期 Oracle DB 23.5新特性一览(20240730)
数据库管理225期 2024-07-30 数据库管理-第225期 Oracle DB 23.5新特性一览(20240730)1 二进制向量维度格式2 RAC上的复制HNSW向量索引3 JSON集合4 JSON_ID SQL函数5 优化的通过网络对NVMe设备的Oracle的原生访问6 DBCA支持PMEM存储7 DBCA支持标准版高可…...
提高生产效率:最佳7大Bug记录工具
本文将分享2024年值得关注的7款Bug记录工具:PingCode、Worktile、禅道、Tapd、CODING、JIRA、Bugzilla。 Bug的管理和跟踪是一个不断挑战的任务,而一个高效的Bug记录工具不仅可以提高团队的生产效率,还能显著降低项目延误的风险。选择合适的工…...
DDOS攻击学习 - kali初学
文章目录 本地ssh配置nmap(网络连接的工具)nmap -sP IP地址nmap -p 1-65535 -A IP地址主机发现Ping扫描端口扫描时序扫描常用扫描方式 指纹识别与探测全端口版本探测防火墙/IDS逃逸报文分段 信息收集IP信息收集WHOIS查询 数据库渗透测试MySQL列举数据库列举MySQL变量 发起请求目…...
【C++】类和对象——流插入和流提取运算符重载
目录 前言ostream和istream自定义类型的流插入重载自定义类型的流提取重载解决私有问题日期类总接口 前言 我们在上一节实现日期类时,在输入和输出打印时,经常会调用两个函数: void Insert()//输入函数{cin >> _year;cin >> _mo…...
Vmware ubuntu20.04 虚拟文件夹
目录 1.vmware 设置 2.ubuntu设置 1.vmware 设置 设置完成后我们开机 2.ubuntu设置 我们打开终端 输入命令 vmware-hgfsclient可以看到你当前的共享文件 然后我们输入以下命令,用于将共享文件夹挂载到虚拟机中 sudo vmhgfs-fuse .host:/ /mnt -o nonempty -o …...
人工智能学习笔记 - 初级篇Ⅱ - 图形可视化 - 第11节: 绘制带填充区域的图表
微信公众号:御风研墨 关注可了解更多。问题或建议,请公众号留言 文章目录 绘制带填充区域的图表应用背景准备工作操作步骤工作原理补充说明最后 绘制带填充区域的图表 应用背景 在数据可视化中,带填充区域的图表可以有效地表示数据范围、趋…...
使用STM32实现一个线性代数计算器
文章目录 背景挑战与困难如何整合编译?error: non-ASM statement in naked function is not supportederror: #pragma import is an ARM Compiler 5 extension, and is not supported by ARM Compiler 6error: redefinition of __FILE 改造demo中的cout改造delete运…...
我在高职教STM32——串口通信(4)
大家好,我是老耿,高职青椒一枚,一直从事单片机、嵌入式、物联网等课程的教学。对于高职的学生层次,同行应该都懂的,老师在课堂上教学几乎是没什么成就感的。正因如此,才有了借助 CSDN 平台寻求认同感和成就感的想法。在这里,我准备陆续把自己花了很多心思的教学设计分享…...
Redis 缓存中间件 缓存数据库
Redis 缓存中间件 缓存数据库 nginx web服务 PHP 转发动态请求 tomcat web页面也可以转发动态请求 springboot 自带tomcat 所有的数据库不支持高并发,一旦访问量激增,数据库很快就会崩溃。 Redis 非关系型数据库 nosql not only sql 不仅仅是sql 键值对…...
51、PHP 实现简单的快速排序
题目: PHP 实现简单的快速排序 描述: function simpleQuickSort(array $list) {$length count($list);if( $length < 1){return $list;}else{$pivot $list[0];$left_list array();$right_list array();for($i 1; $i < $length; $i){if($lis…...
基于距离变化能量开销动态调整的WSN低功耗拓扑控制开销算法matlab仿真
目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.算法仿真参数 5.算法理论概述 6.参考文献 7.完整程序 1.程序功能描述 通过动态调整节点通信的能量开销,平衡网络负载,延长WSN生命周期。具体通过建立基于距离的能量消耗模型&am…...
SCAU期末笔记 - 数据分析与数据挖掘题库解析
这门怎么题库答案不全啊日 来简单学一下子来 一、选择题(可多选) 将原始数据进行集成、变换、维度规约、数值规约是在以下哪个步骤的任务?(C) A. 频繁模式挖掘 B.分类和预测 C.数据预处理 D.数据流挖掘 A. 频繁模式挖掘:专注于发现数据中…...
Opencv中的addweighted函数
一.addweighted函数作用 addweighted()是OpenCV库中用于图像处理的函数,主要功能是将两个输入图像(尺寸和类型相同)按照指定的权重进行加权叠加(图像融合),并添加一个标量值&#x…...
家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
Axios请求超时重发机制
Axios 超时重新请求实现方案 在 Axios 中实现超时重新请求可以通过以下几种方式: 1. 使用拦截器实现自动重试 import axios from axios;// 创建axios实例 const instance axios.create();// 设置超时时间 instance.defaults.timeout 5000;// 最大重试次数 cons…...
华硕a豆14 Air香氛版,美学与科技的馨香融合
在快节奏的现代生活中,我们渴望一个能激发创想、愉悦感官的工作与生活伙伴,它不仅是冰冷的科技工具,更能触动我们内心深处的细腻情感。正是在这样的期许下,华硕a豆14 Air香氛版翩然而至,它以一种前所未有的方式&#x…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
Qemu arm操作系统开发环境
使用qemu虚拟arm硬件比较合适。 步骤如下: 安装qemu apt install qemu-system安装aarch64-none-elf-gcc 需要手动下载,下载地址:https://developer.arm.com/-/media/Files/downloads/gnu/13.2.rel1/binrel/arm-gnu-toolchain-13.2.rel1-x…...
Python 训练营打卡 Day 47
注意力热力图可视化 在day 46代码的基础上,对比不同卷积层热力图可视化的结果 import torch import torch.nn as nn import torch.optim as optim from torchvision import datasets, transforms from torch.utils.data import DataLoader import matplotlib.pypl…...
【51单片机】4. 模块化编程与LCD1602Debug
1. 什么是模块化编程 传统编程会将所有函数放在main.c中,如果使用的模块多,一个文件内会有很多代码,不利于组织和管理 模块化编程则是将各个模块的代码放在不同的.c文件里,在.h文件里提供外部可调用函数声明,其他.c文…...
