uniapp多页面同时监听一个值

文章讲述了在Vue应用中,A和B页面同时监听store中的ConnectStatus值导致的跳转问题。解决方法是A页面监听,B页面不监听,通过Vue的watcher机制实现连接状态变化时的相应操作。
摘要由CSDN通过智能技术生成

遇到的问题

两个页面同时监听store中的同一个值ConnectStatus,A页面中获取到ConnectStatus值为1时跳转index页面,B页面中获取到ConnectStatus值不为1时跳转first页面。现在是A页面ConnectStatus为1时跳转的是first页面。

解决方案

进入A页面,A页面监听ConnectStatus,B页面不监听;进入B页面,B页面监听ConnectStatus,A页面不监听。

解决方法

1.App.vue:
         globalData: {
                wather:''
          },
 2.页面(A、B页面都需要写):
 computed: {
    connectStatus() {
        return this.state.ConnectStatus
    }
},
onShow() {
    this.$createWatcher('changeAuth')
},
onBackPress() {
    console.log('有没有被销毁')
    this.$removeWatcher()
},                //返回没有被销毁加的onBackPress(),跳转进入onHide()
onHide() {
    this.$removeWatcher()
},
methods:{
    $createWatcher(name) {
        getApp().globalData.watcher = this.$watch(
                'connectStatus', 
                (newVal, oldVal) => {
                    this[name](this.connectStatus)
                }, {
                deep: true,
                immediate: true
            })
    },
    $removeWatcher() {
        // 检查是否有已存在的观察者
        if (getApp().globalData.watcher) {
            // 调用观察者返回的取消函数,即取消对特定属性的监听
            getApp().globalData.watcher()
            console.log('Watch 移除成功!')
        } else {
            console.log('没有观察者可移除!')
        }
    },
    changeAuth(newVal) {
        if (newVal === 1) {
            this.connect();//编辑自己的代码
        }
    },
}

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
uniapp,你可以通过以下几种方式监听页面滚动高度: 1. 使用生命周期的onPageScroll方法。在普通页面,你可以在onPageScroll方法传入scrollTop,并触发所有easy-loadimage组件下的滚动监听事件。具体代码如下: ```javascript onPageScroll(e) { this.scrollTop = e.scrollTop; // 传入scrollTop // 触发所有easy-loadimage组件下的滚动监听事件 }, ``` \[1\] 2. 使用window.onscroll事件。为了保证兼容性,你可以取三个的任意一个来获取滚动高度,即window.pageYOffset、document.documentElement.scrollTop和document.body.scrollTop。具体代码如下: ```javascript window.onscroll = function () { var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop; // 获取滚动高度 console.log("滚动距离" + scrollTop); } ``` \[2\] 3. 使用scroll-view标签。在uniapp,你可以使用scroll-view标签来实现滚动条,并监听滚动事件。具体代码如下: ```html <scroll-view scroll-y="true" class="scroll-Y" @scrolltoupper="upper" @scrolltolower="lower" @scroll="scroll"></scroll-view> ``` \[3\] 以上是uniapp监听页面滚动高度的几种方式,你可以根据自己的需求选择其一种来实现。 #### 引用[.reference_title] - *1* [uniapp页面滚动监听](https://blog.csdn.net/chenrui310/article/details/128536818)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [uniapp监听页面与滚动h5监听页面滚动](https://blog.csdn.net/gcyaozuodashen/article/details/125327848)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [uniapp 小程序 监听数据渲染完毕 获取高度 滚动条滚动到最底部](https://blog.csdn.net/qq_47247479/article/details/128203828)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值