uniapp点击按钮页面滚动到自定义位置

文章描述了在UniApp中,如何通过点击按钮使页面滚动到指定的自定义位置,当存在多条功能且高度不同时,利用JavaScript获取滚动高度并动态计算移动目标,实现功能跳转。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

uniapp点击按钮页面滚动到自定义位置

功能介绍:记录存在很多条的情况下,需要通过点击一个按钮,跳转到该功能的最开始的地方,由于上面的功能高度不一致,所以需要动态去获取滚动的高度。
在这里插入图片描述

<view class="bottomMenu history u-rela" @click="viewHistory">
	<u-badge type="error" :count="historyNum" :offset="[-10, -10]"></u-badge>
</view>
//js部分
data() {
    return {
        scrollTop: 0,
        statusHeight:0
    }
},
onPageScroll(e) {
    //获取滚动高度
	this.scrollTop = e.scrollTop;
},
onLoad(args) {
	uni.getSystemInfo({
       	success:(res)=>{
		//获取状态栏高度 
		this.statusHeight = res.statusBarHeight;
       }
    });
},
methods: {
    //点击按钮跳转
	viewHistory() {
    	var that = this;
   		this.$u.getRect('.jumpHistory').then(res => {
            uni.pageScrollTo({
                //移动高度=滚动高度 + 距离上面的位置 - 导航条 - 状态栏高度
                scrollTop: that.scrollTop + res.top -44 - that.statusHeight,
                duration: 300
            });
        })
    },
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值