微信小程序网络更换后Websocket失效
2021/10/28 9:39:31
本文主要是介绍微信小程序网络更换后Websocket失效,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
Hello,I’m Shendi
当设备更换网络后,微信小程序的WebSocket将失效,此时进行发送等都会触发 fail 函数
解决方法
首先我想到的是,因为失败会触发 fail 函数,那么理应可以在 fail 中进行重新打开websocket并重新发送
然后代码写好,发现问题没有得到解决
猜到打开操作是异步执行,于是我在重新打开后,定时1秒,2秒左右在进行发送
(问题解决了,但是因为定时,导致其他功能出现了问题,而且有时会出现死循环的情况)
然后想到,通过监听网络的方式来重新打开 websocket
这样也可以进行提示,我的问题得到了完善的解决
通过以下API
https://developers.weixin.qq.com/miniprogram/dev/api/device/network/wx.onNetworkStatusChange.html
// app.js 的 onLaunch 加入以下代码 // 监听网络变化 wx.onNetworkStatusChange(function (res) { // 网络连接时重新打开websocket,否则提示无网 console.log("监听到网络状态切换:" + res.isConnected); if (res.isConnected) { // 重新打开websocket that.reopen(); wx.showToast({ title: '网络已连接!' }); } else { wx.showToast({ title: '设备无网络!', icon : "error" }); } });
这篇关于微信小程序网络更换后Websocket失效的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-13微信小程序如何封装接口域名?-icode9专业技术文章分享
- 2024-11-13如何在微信小程序中实现直传功能?-icode9专业技术文章分享
- 2024-11-13如何在小程序的地图组件中添加标记和文字?-icode9专业技术文章分享
- 2024-11-13在微信小程序的地图组件中如何实现自定义标记和气泡?-icode9专业技术文章分享
- 2024-11-01微信小程序教程:零基础入门到实战
- 2024-11-01微信小程序全栈教程:从入门到实践
- 2024-10-31微信小程序怎么实现关注公众号功能-icode9专业技术文章分享
- 2024-10-30微信小程序cover-view,支持bindtap吗-icode9专业技术文章分享
- 2024-10-30微信小程序的cover-image支持bindtap吗-icode9专业技术文章分享
- 2024-10-30微信小程序web-view怎么设置高度?-icode9专业技术文章分享