uniapp 全局变量(如何在uniapp项目中使用mqtt)
类别:编程学习 浏览量:701
时间:2022-04-02 10:11:11 uniapp 全局变量
如何在uniapp项目中使用mqtt目录
- 一、uniapp插件市场的参考插件
- 二、具体引入过程
- 1.安装mqtt和uuid
- 2.页面引入mqtt并调用
- 3.运行结果
由于要取一些实时数据并在手机app上展示,就想到用mqtt进行即时通讯。
下面附上uniapp中引入mqtt的全过程:
一、uniapp插件市场的参考插件https://ext.dcloud.net.cn/plugin?id=854
二、具体引入过程1.安装mqtt和uuid
在uniapp项目根目录下分别运行安装mqtt和uuid的命令行,因为后面会用uuid生成mqtt的clientId,所以这边就一起安装了。
npm install mqtt@3.0.0 npm install uuid
Ps.
①我这里和uniapp提供的插件安装的mqtt版本一样,我也尝试装了最新的版本,会报错,emmmmm...........
②如果没有pakage.json,安装是会提示报错,但是不影响安装使用。如果想方便一点,下次拉代码直接安装的话,可以自己在项目根目录下加一个pakage.json文件,添加如下内容:
{ "name": "", "version": "1.0.0", "description": "", "author": "", "license": "MIT", "dependencies": { "mqtt": "^3.0.0", "uuid": "^8.3.0" }, "devDependencies": {}, "scripts": {} }
2.页面引入mqtt并调用
①mqtt连接配置,放在/utils/mqtt.js里面,全局可用。
export const MQTT_IP = '192.168.9.128:8083/mqtt'//mqtt地址端口 const MQTT_USERNAME = 'public'//mqtt用户名 const MQTT_PASSWORD = 'public'//密码 export const MQTT_OPTIONS = { connectTimeout: 5000, clientId: '', username: MQTT_USERNAME, password: MQTT_PASSWORD, clean: false }
②vue页面引用mqtt
mqtt里面的clientId用uuid生成唯一标识码,防止不同页面订阅不同主题时数据出现粘连。
<script> import { v4 } from 'uuid'; import { MQTT_IP, MQTT_OPTIONS } from '@/utils/mqtt.js'; var mqtt = require('mqtt/dist/mqtt.js') var client export default { data() { return { topic: '' //要订阅的主题 } }, mounted() {this.connect() //连接 }, methods: { connect() { MQTT_OPTIONS.clientId = v4() var that = this // #ifdef H5 client = mqtt.connect('ws://' + MQTT_IP, MQTT_OPTIONS) // #endif // #ifdef MP-WEIXIN||APP-PLUS client = mqtt.connect('wx://' + MQTT_IP, MQTT_OPTIONS) // #endif client.on('connect', function() { console.log('连接成功') client.subscribe(that.topic, function(err) { if (!err) { console.log('订阅成功') } }) }).on('reconnect', function(error) { console.log('正在重连...', that.topic) }).on('error', function(error) { console.log('连接失败...', error) }).on('end', function() { console.log('连接断开') }).on('message', function(topic, message) { console.log('接收推送信息:', message.toString()) }) } } } </script>
3.运行结果
数据实时变化。
以上就是uniapp中使用mqtt的方法分享。
以上就是如何在uniapp项目中使用mqtt的详细内容,更多关于uniapp使用mqtt的资料请关注开心学习网其它相关文章!
您可能感兴趣
- 微信小程序可以用百度的echarts吗(uniapp在微信小程序中使用ECharts的方法)
- yii与uniapp交互(Yii框架的路由配置方法分析)
- uni app开发教程(uniapp+Html5端实现PC端适配)
- uni-app项目开发教程学习(分析uniapp如何动态获取接口域名)
- uni app 小程序全局样式没法用(uniapp封装小程序雷达图组件的完整代码)
- uniapp使用vue写页面(分析uniapp入门之nvue爬坑记)
- uniapp 动态表单(详解uniapp无痛刷新token方法)
- uniapp 全局变量(如何在uniapp项目中使用mqtt)
- 提醒 2019年起河南驾考要开设科目五 官方回应来了(2019年起河南驾考要开设科目五)
- 省 市书法家协会 送万福进万家 活动走进禹州美丽乡村(省市书法家协会)
- 点赞 禹州苌庄正式撤乡建镇 未来发展不可估量(禹州苌庄正式撤乡建镇)
- 它荣获 中国生态魅力镇 称号 就在咱们禹州,一起来看看(中国生态魅力镇)
- 真牛 禹州将建成中等城市(禹州将建成中等城市)
- 被骂欺师灭祖,与郭德纲公开叫板,何云伟改名何沄伟,开始画画了(与郭德纲公开叫板)
热门推荐
- dockerfile自定义镜像图解(Docker images导出和导入操作)
- divcss页面布局步骤(横向两列布局左列固定,右列自适应的4种CSS实现方式)
- sqlserver拒绝访问怎么办(SQL server服务显示远程过程调用失败的解决方法)
- 宝塔linux面板开哪些端口(Linux宝塔面板如何实现服务器开启关闭禁止ping?)
- 微信小程序语音录入(微信小程序使用同声传译实现语音识别功能)
- vue3 兄弟组件(vue3如何按需加载第三方组件库详解)
- 如何修改dedecms(dedecms做英文站修改方法)
- macos安装虚拟机教程(VMware虚拟机安装苹果Mac OS的超详细教程)
- pytorch入门与实战(详解PyTorch基本操作)
- php用什么解压(php解压缩zip和rar压缩包文件的方法)