解决使用 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>
相关推荐
每天都要加油呀!21 小时前
TypeError: uni.requestPayment is not a function
小程序
java1234_小锋21 小时前
分享一套优质的微信小程序校园志愿者系统(SpringBoot后端+Vue3管理端)
微信小程序·小程序·校园志愿者
2501_916008891 天前
深入解析iOS机审4.3原理与混淆实战方法
android·java·开发语言·ios·小程序·uni-app·iphone
打破砂锅问到底0071 天前
AI 驱动开发实战:10分钟从零构建「微信群相册」小程序
人工智能·微信·小程序·ai编程
CHU7290351 天前
扭蛋机盲盒小程序前端功能设计解析:打造趣味与惊喜并存的消费体验
前端·小程序
QT.qtqtqtqtqt1 天前
uni-app小程序前端开发笔记(更新中)
前端·笔记·小程序·uni-app
CHU7290351 天前
直播商城APP前端功能全景解析:打造沉浸式互动购物新体验
java·前端·小程序
喵喵虫1 天前
uniapp修改封装组件失败 styleIsolation
uni-app
黑客老李1 天前
web渗透实战 | js.map文件泄露导致的通杀漏洞
安全·web安全·小程序·黑客入门·渗透测试实战
游戏开发爱好者82 天前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview