vue中使用mqtt插件实现通信
admin
2024-02-14 05:08:32
0

1、使用npm install下载mqtt插件

npm install mqtt

2、创建mqtt.js文件封装mqtt

import mqtt from 'mqtt'// 如果url不是固定的,可以把这个改成参数
const url = 'ws://xxx.xx.xx.xx:8083/webSocket'class MqttClient {constructor() {this.websockets = null}connect(callback) {// 1. 创建websockets对象,参数为服务器websockets地址this.websockets = new WebSocket(url)// 2.监听websocket的状态变化,接收的信息,关闭时的状态this.websockets.onopen = (event) => {console.log('连上了')}this.websockets.onmessage = (res) => {console.log('接收到了', res)callback(res)}}close() {this.websockets.close()}async login(topic, fn) {// 1. 创建websockets对象,参数为服务器websockets地址this.websockets = new WebSocket(url)// 2.监听websocket的状态变化,接收的信息,关闭时的状态// 监听连接状态的变化// this.websockets.onopen = (event) => socketChange()this.websockets.onopen = (event) => {console.log('链接状态改变了')}// 监听接收消息的情况this.websockets.onmessage = (res) => {// document.querySelector('#message').innerHTML += `

接收数据: ${res.data}

`console.log('接收到了', res)}}logout() {return this.clients.map((client) => {if (client && client.connected) {return client.end().then(() => {this.clients = []this.clientId = null})}return Promise.resolve().then(() => {this.clients = []this.clientId = null})})}// 监听接收消息on() {this.client.on('message', (topic, message) => {if (message) {console.log('收到来着', topic, '的信息', message.toString())const res = JSON.parse(message.toString())this.msg = res}})}off() {this.client.unsubscribe(this.mtopic, (error) => {console.log('主题为' + this.mtopic + '取消订阅成功', error)})}// 断开连接unconnect() {this.client.end()this.client = nullconsole.log('服务器已断开连接!')}// 监听服务器重新连接reconnect() {this.client.on('reconnect', (error) => {console.log('正在重连:', error)})}// 监听服务器是否连接失败mqttError() {this.client.on('error', (error) => {console.log('连接失败:', error)this.client.end()})} }export default MqttClient

3、页面使用

在页面中引入封装好的mqtt

import Mqtt from './utils/mqtt'
const mqttClient = new Mqtt()
export default {mounted() {// 链接mqttClient.connect(this.receiveMessage)// 监听页面销毁时断开mqttthis.$on('hook:beforeDestroy', () => {mqttClient.close()})},methods: {// json就是返回的消息内容receiveMessage(json) {}}
}

以上就是最近使用mqtt的相关内容,记录一下,避免以后需要的时候找不到

相关内容

热门资讯

汽车加装安卓系统卡住,探究原因... 你有没有遇到过这样的尴尬情况:汽车加装了安卓系统,结果屏幕突然卡住了,就像被施了魔法一样,怎么也动弹...
电量壁纸安卓系统下载,打造个性... 手机电量告急,是不是又得赶紧找充电宝了?别急,今天就来给你安利一款超实用的电量壁纸,让你的安卓手机瞬...
iPhonex里面是安卓系统,... 你有没有想过,那个我们每天都离不开的iPhone,里面竟然可能是安卓系统?是的,你没听错,就是那个以...
ios系统比安卓系统好在哪里,... 你有没有想过,为什么有些人对iOS系统情有独钟,而有些人却对安卓系统爱不释手呢?今天,就让我带你从多...
安卓系统跟踪设置大小,跟踪设置... 你知道吗?现在智能手机几乎成了我们生活的必需品,而安卓系统作为全球最受欢迎的操作系统之一,它的跟踪设...
在线迎新系统下载安卓,轻松开启... 你有没有想过,开学季的到来,就像一场盛大的狂欢,而在这个狂欢中,有一个小助手,它默默地守护着你的入学...
安卓系统怎么申请微信号,一键申... 你有没有想过,在安卓手机上申请一个微信账号,竟然也能变得如此简单?没错,就是那个我们每天离不开的社交...
安卓手机系统里怎么清理,轻松优... 手机里的东西越来越多,是不是感觉安卓手机系统越来越慢了呢?别急,今天就来教你怎么清理安卓手机系统,让...
安卓系统改定位地址软件,轻松掌... 你是不是也和我一样,有时候想换个角度看世界,但又不想真的搬家?别急,今天就来给你揭秘一个神奇的小工具...
安卓10系统里的Google,... 你有没有发现,自从你的安卓手机升级到了10系统,Google的功能好像变得更加贴心了呢?今天,就让我...
安卓app刷量留存系统,高效策... 你有没有想过,那些在手机上下载的安卓应用,它们是如何吸引你的注意,又是如何让你一刷再刷的呢?今天,就...
安卓app答题系统功能数据,全... 你有没有想过,手机里那些答题APP,它们是怎么做到让你在轻松愉快的氛围中学习新知识的呢?今天,就让我...
安卓系统iso镜像下载地址,轻... 你有没有想过,想要给你的安卓设备来个焕然一新的变身?那就得来点技术活儿——下载一个安卓系统的ISO镜...
微软安卓系统删除不了,删除操作... 你有没有遇到过这种情况?手机里突然多了一个微软安卓系统,怎么也删不掉,真是让人头疼啊!这不,最近就有...
安卓系统能查隐私吗,隐私查询与... 你有没有想过,你的安卓手机里藏着多少秘密?是不是好奇过,有没有什么方法可以窥探这些隐私呢?今天,就让...
安卓系统的掌上炫舞,安卓平台上... 你有没有发现,最近你的手机里多了一个新伙伴?没错,就是安卓系统的掌上炫舞!这款游戏可是风靡一时,让无...
安卓系统怎么删除小红标,安卓系... 手机里的小红标是不是让你觉得有点碍眼呢?别急,今天就来教你怎么轻松地把它从安卓系统中删除掉,让你的手...
安卓系统播放路由器,打造无缝网... 你有没有想过,家里的安卓系统设备想要畅快地享受网络,其实只需要一个小小的助手——那就是路由器!今天,...
基于安卓系统的人脸识别,人脸识... 你有没有想过,在手机解锁的时候,只需轻轻一瞥,就能瞬间解锁?这就是基于安卓系统的人脸识别技术的魅力所...
1km安卓系统下载,高效便捷的... 你有没有想过,手机系统升级竟然也能成为一场说走就走的旅行?没错,今天就要带你领略如何轻松下载1km安...