解决使用 UniApp 搭配 Vue3 小程序开始 使用uview-plus 的返回顶部up-back-top中onPageScroll 不触发的问题

解决使用 UniApp 搭配 Vue3 小程序开始 使用uview-plus 的返回顶部up-back-top中onPageScroll 不触发的问题

页面引入方法都正确 结果方法不触发

javascript 复制代码
<up-back-top :scroll-top="scrollTop"></up-back-top>
<script setup>  
import { ref } from 'vue';  
import { onPageScroll } from '@dcloudio/uni-app';
  
// 创建响应式数据 scrollTop  
const scrollTop = ref(0);  
  
// onPageScroll 方法来更新 scrollTop 的值  
onPageScroll((e) => {
	scrollTop.value = e.scrollTop;
});
</script>

排查问题后发现 需要注意以下几个问题 否则不会触发箭监听滚动 onPageScroll 方法

第一:最外层盒子容器的 css中 需要设置高度 但是不能设置:overflow: hidden 或者overflow-y: auto或overflow-y: scroll

第二:使用了自定义导航栏 需要设置 navigationStyle: custom

第三:在 pages.json 的页面配置中,需要确保未禁用滚动监听 "disableScroll": false

javascript 复制代码
// pages.json
{
    "pages": [{
        "path": "pages/index/index",
        "style": {
            "navigationBarTitleText": "首页",
            "disableScroll": false // 确保为 false
        }
    }]
}

完成以上 即可实现返回顶部组件生效

========================================================

如果不想使用组件 自定义方法

javascript 复制代码
<view class="upward" v-if="isShow" @click="Totop()">
   <u-icon name="arrow-upward" color="#434343" size="28"></u-icon>
</view>
<script setup>  
import { ref } from 'vue';  
import { onPageScroll } from '@dcloudio/uni-app';
// 创建响应式数据 scrollTop  
//const scrollTop = ref(0);  
let isShow = ref(false)
// onPageScroll 方法来更新 scrollTop 的值 这个方法需要注意上面三点问题 是否不一致
onPageScroll((e) => {
	//scrollTop.value = e.scrollTop;
	if(e.scrollTop > 400){
		isShow.value = true
	}else{
		isShow.value = false
	}
});
function Totop(){
	uni.pageScrollTo({
       scrollTop: 0,//滚动到页面的目标位置
       duration: 300
   	});
}
</script>
相关推荐
阿凤2115 小时前
uniapp运行到app端怎么打开文件
android·前端·javascript·uni-app
00后程序员张16 小时前
完整教程:如何将iOS应用程序提交到App Store审核和上架
android·macos·ios·小程序·uni-app·cocoa·iphone
00后程序员张16 小时前
iOS应用性能优化全解析:卡顿、耗电、启动与瘦身
android·ios·性能优化·小程序·uni-app·iphone·webview
大力水手~19 小时前
小程序模仿iphone苹果手机滑动选时间
智能手机·小程序
杰建云16719 小时前
小程序如何做裂变?
小程序·小程序制作
Front思20 小时前
解决 uniapp Dart Sass 2.0.0 弃用警告
前端·uni-app·sass
阳光雨滴20 小时前
微信小程序使用canvas自定义富文本内容做图片分享
微信小程序·小程序
杰建云16720 小时前
小程序如何做活动?
小程序·小程序制作
这是个栗子20 小时前
【微信小程序问题解决】微信小程序全局 navigationBarTitleText 不起作用
微信小程序·小程序·导航栏
lpfasd12321 小时前
从“惯性思维”到“规则驱动”:一次微信小程序修复引发的 AI 编程范式思考
人工智能·微信小程序·小程序