VUE3+mqtt封裝解決多頁(yè)面使用需重復(fù)連接等問(wèn)題(附實(shí)例)
場(chǎng)景:
在做的一個(gè)項(xiàng)目中多個(gè)頁(yè)面都需要使用到mqtt接收消息,但這樣的話每個(gè)頁(yè)面就都需要連接一次mqtt,并且要再次配置options信息、訂閱主題、接收消息,非常的不方便,因此琢磨將mqtt封裝到vuex中,使其可以多頁(yè)面通用,這樣只需要連接訂閱一次,接收到的消息可以存儲(chǔ)在vuex中。
mqtt在線測(cè)試工具:http://www.emqx.io/online-mqtt-client
一、安裝mqtt
npm install mqtt
二、暴露出main.js中的vue實(shí)例
使用export default暴露出app
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
const app = createApp(App)
app.use(ElementPlus)
app.use(store).use(router).mount('#app')
export default app
三、封裝mqtt
將mqtt服務(wù)封裝到VUEX中,可以解決多頁(yè)面需要用到mqtt接收消息時(shí),每個(gè)頁(yè)面都要再次配置、連接、訂閱主題等問(wèn)題
import { createStore } from 'vuex'
import main from "../main";//main.ts文件中要暴露app
import router from '@/router';// 引入vuex
export default createStore({
state: {
topics: [],//訂閱話題
},
mutations: {
//mqtt服務(wù)
MQTT_SERVICE(state, event){
// mqtt連接成功
main.config.globalProperties.$mqtt.on('connect', (e) => {
console.log('連接成功:', e)
// console.log(state.topics)
main.config.globalProperties.$mqtt.subscribe(state.topics, { qos: 1 }, (error) => {
if (!error) {
console.log('訂閱成功')
} else {
console.log('訂閱失敗')
}
})
})
// 接收消息處理
main.config.globalProperties.$mqtt.on('message', (topic, message) => {
console.log('收到來(lái)自', topic, '的消息', message.toString())
})
// 斷開發(fā)起重連
main.config.globalProperties.$mqtt.on('reconnect', (error) => {
console.log('正在重連:', error)
})
// 鏈接異常處理
main.config.globalProperties.$mqtt.on('error', (error) => {
console.log('連接失敗:', error)
})
},
//發(fā)布消息
MQTT_PUBLISH(state, {topic, msg}){
console.log(topic)
main.config.globalProperties.$mqtt.publish(topic, msg)
},
//斷開MQTT
MQTT_CLOSE(state, event){
console.log('斷開MQTT');
main.config.globalProperties.$mqtt.end()
},
},
actions: {
},
modules: {
}
})
四、編寫mqtt配置文件
在src下的utils下新建一個(gè)js文件:mqttConfig.js
更多options配置參數(shù)參考mqtt文檔:https://github.com/mqttjs/MQTT.js
import $store from "@/store/index";
export function getOptions(){
let options = {
connectTimeout: 40000,
clientId: 'mqttId',
clean: true,
username: admin,
password: admin
}
return options
}
export function setTopics(){
//此處修改VUEX中的值建議通過(guò)actions、mutations修改state值
$store.state.topics = [ 'topic01','topic02','topic03''topic04''topic05']
}
五、頁(yè)面引入并使用
這里是在一個(gè)所有頁(yè)面都要用到的一個(gè)公共組件中引入使用的,也可以在main.js中使用(看引入方法二)
方法一:公共組件中引入
import { computed, reactive, ref ,defineComponent, onMounted, onUnmounted } from 'vue-demi';
import $store from "@/store/index";//引入VUEX
import main from "../main";//main.ts文件中要暴露app
import { getOptions, setTopics } from "@/utils/mqttConfig.js"
import mqtt from 'mqtt'//引入mqtt
//mqtt鏈接地址
let mqttUrl = 'ws://broker.emqx.io:8084'
export default defineComponent ({
name:'msgDisplay',
setup(){
onMounted(() => {
//mqtt連接
main.config.globalProperties.$mqtt = mqtt.connect(mqttUrl, getOptions())
//設(shè)置訂閱主題
setTopics()
//啟動(dòng)mqtt狀態(tài)監(jiān)聽
$store.commit('MQTT_SERVICE')
})
onUnmounted(() => {
$store.commit('MQTT_CLOSE') //斷開mqtt
})
return { }
}
})
</script>
方法二:main中引入
該方法需要在main中創(chuàng)建連接,在首頁(yè)的渲染生命周期中啟動(dòng)mqtt狀態(tài)監(jiān)聽
main.js:
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
const app = createApp(App)
import mqtt from 'mqtt'
import { getOptions, setTopics } from "./utils/mqttConfig.js"
let mqttUrl = 'ws://broker.emqx.io:8084'
//mqtt連接
app.config.globalProperties.$mqtt = mqtt.connect(mqttUrl, getOptions())
//設(shè)置訂閱主題
setTopics()
app.use(ElementPlus)
app.use(store).use(router).mount('#app')
export default app
首頁(yè).vue:
<script>
import { onMounted, defineComponent, onUnmounted } from 'vue';
import $store from "@/store/index";
export default defineComponent ({
setup(){
onMounted(() => {
//啟動(dòng)mqtt狀態(tài)監(jiān)聽
$store.commit('MQTT_SERVICE')
})
onUnmounted(() => {
//關(guān)閉項(xiàng)目時(shí)斷開mqtt
//此處僅適用于從首頁(yè)跳轉(zhuǎn)到下一個(gè)頁(yè)面后首頁(yè)沒(méi)有被銷毀的情況,其它情況自行修改
$store.commit('MQTT_CLOSE')
})
}
})
</script>
至此mqtt封裝結(jié)束,此文為mqtt使用過(guò)程中的個(gè)人封裝筆記,如有不足或可改進(jìn)之處還請(qǐng)指出。
總結(jié)
到此這篇關(guān)于VUE3+mqtt封裝解決多頁(yè)面使用需重復(fù)連接等問(wèn)題的文章就介紹到這了,更多相關(guān)VUE3 mqtt封裝解決重復(fù)連接內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決vue.js 數(shù)據(jù)渲染成功仍報(bào)錯(cuò)的問(wèn)題
今天小編就為大家分享一篇解決vue.js 數(shù)據(jù)渲染成功仍報(bào)錯(cuò)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08
Vue @click.stop阻止事件向祖先元素傳遞方式(事件冒泡)
在Vue中,使用@click.stop修飾符可以阻止事件向父級(jí)元素傳遞,從而實(shí)現(xiàn)單擊父級(jí)元素執(zhí)行函數(shù),而單擊子元素不執(zhí)行函數(shù)的需求2025-02-02
vue3+vite項(xiàng)目中按需引入vant報(bào)錯(cuò):Failed?to?resolve?import的解決方案
最近在vue項(xiàng)目中引入vant的時(shí)候發(fā)現(xiàn)報(bào)錯(cuò)了,經(jīng)過(guò)嘗試發(fā)現(xiàn)了問(wèn)題,現(xiàn)將完整引入流程提供給大家參考,下面這篇文章主要給大家介紹了關(guān)于vue3+vite項(xiàng)目中按需引入vant報(bào)錯(cuò):Failed?to?resolve?import的解決方案,需要的朋友可以參考下2022-12-12
vue 使用localstorage實(shí)現(xiàn)面包屑的操作
這篇文章主要介紹了vue 使用localstorage實(shí)現(xiàn)面包屑的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
Vue中動(dòng)態(tài)Class實(shí)戰(zhàn)示例
這篇文章主要為大家介紹了Vue中動(dòng)態(tài)Class的實(shí)戰(zhàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11
vue3.0如何修改瀏覽器標(biāo)題(靜態(tài))
這篇文章主要介紹了vue3.0如何修改瀏覽器標(biāo)題(靜態(tài)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
vue上傳文件formData入?yún)榭?接口請(qǐng)求500的解決
這篇文章主要介紹了vue上傳文件formData入?yún)榭?接口請(qǐng)求500的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06

