已解决,很蠢的问题,结题
关于自定义TabBar消息 未读 | 已读 状态问题?<template> <uni-transition mode-class="fade" :duration="200" :show="true"> <view class="main_box"> <index v-if="currentIndex === 0"></index> <myDoctor v-if="currentIndex === 1"></myDoctor> <message v-if="currentIndex === 2"></message> <prescript v-if="currentIndex === 3"></prescript> <my v-if="currentIndex === 4"></my> </view> <view class="foot_box"> <!-- <custom-tab-bar ref='tabbar' :currentIndex="currentIndex" @update:currentIndex="updateCurrentIndex"> </custom-tab-bar> --> <uni-transition mode-class="fade" :duration="200" :show="true"> <view> <view class="tab-content"> <slot /> </view> <view class="tabbar"> <view class="navigator"> <view ref='warpper' class="warpper"> <view ref="navItem" class="navigator-item" v-for="(item,index) in tabBar.list" :key="item.pagePath" @click="switchTab(item,index)" :data-index='index'> <img :src="item.iconPath" class="icon" v-if="selectedIndex !== index"> <img :src="item.selectedIconPath" :class="[item.selectIconStyle ? 'icon-select' : 'icon']" v-else> <text :class="['item-text',{'text-active':selectedIndex === index}]">{{item.text}}</text> <view v-if="item.hasUnreadMessage" class="unread-dot"></view> </view> </view> </view> </view> </view> </uni-transition> </view> </uni-transition> </template> <script> import { FILE_URL } from '../../api/base_api.js'; import { GET_MESSAGE } from '../../api/user.js'; var Hub = require('../../utils/signalR.js') var $th_is = this import index from '@/pages/index/index.vue' import myDoctor from '@/pages/my-doctor/my-doctor.vue' import message from '@/pages/message/message.vue' import prescript from '@/pages/prescript/prescript.vue' import my from '@/pages/person/person.vue' export default { components: { index, my, message, prescript, myDoctor }, data() { return { currentIndex: uni.getStorageSync('selectedIndex') || 0, selectedIndex: uni.getStorageSync('selectedIndex') || 0, // 标记 tabBar: { list: [{ pagePath: "pages/index/index", text: "首页", iconPath: "../../static/images/tabbar/home.png", selectedIconPath: "../../static/images/tabbar/home1.png" }, { pagePath: "pages/my-doctor/my-doctor", text: "我的医生", iconPath: "../../static/images/tabbar/doctor.png", selectedIconPath: "../../static/images/tabbar/doctor1.png" }, { pagePath: "pages/message/message", text: "消息", iconPath: "../../static/images/tabbar/message.png", selectedIconPath: "../../static/images/tabbar/message1.png", hasUnreadMessage: uni.getStorageSync("inline-msg") }, { pagePath: "pages/prescript/prescript", text: "药膳商城", iconPath: "../../static/images/tabbar/mingyao2.png", selectedIconPath: "../../static/images/tabbar/mingyao3.png", selectIconStyle: true }, { pagePath: "pages/person/person", text: "我的", iconPath: "../../static/images/tabbar/my2=.png", selectedIconPath: "../../static/images/tabbar/my1.png" } ] }, } }, methods: { loadsocket() { if (this.timeout) { clearTimeout(this.timeout); } this.hubConnect = new Hub.HubConnection(); this.hubConnect.token = uni.getStorageSync('WX_TOKEN') this.hubConnect.start(FILE_URL + "/api/chathub"); this.hubConnect.onOpen = res => {} this.hubConnect.on("Receive", function(res) { uni.setStorageSync("inline-msg", true) console.log("有数据了", res); }) this.hubConnect.on("UsingCode", res => {}) this.hubConnect.on("UsedCode", res => {}) }, switchTab(item, index) { this.currentIndex = index; this.tabBar.list.forEach((v, i) => { if (item.pagePath === v.pagePath) { uni.setStorageSync('selectedIndex', index); } }) this.selectedIndex = uni.getStorageSync('selectedIndex') }, }, onShow() { }, mounted() { this.loadsocket() }, } </script> 这是我做的自定义tabbar,因为需要改样式,所以五个tabbar是一个页面 [图片] 然后ws收到消息后,消息红点不显示,必须刷新一下才显示 [图片] 如果是有消息的话,点击消息,再出来,若是红点存在,他也不会消失,必须刷新一下才消失 [图片] 有人跟我说让我放在data中,我放了,红点出都不出了,我想使用 this.$store 却发现 store并没被挂载,main.js明明是有的 = =!!!! 请问这种情况如何解决,实时红点问题
2024-03-18