uniapp 滚动到页面指定的数据位置

一般情况下可使用以下写法:

uni.createSelectorQuery().in(this).select('.roll').boundingClientRect(res => {
    uni.pageScrollTo({
         //过渡时间必须为0,uniapp bug,否则运行到手机会报错
          duration:0,
         //滚动到实际距离是元素距离顶部的距离减去最外层盒子的滚动距离,这个位置可根据实际情况                    
         //res.top ± num
          scrollTop:res.top,
     })
}).exec();

上述写法可以适用于很多场景,但是某些场景下则需结合 this.$nextTick 和 setTimeout 使用,写法如下:  

this.$nextTick(() => {
     setTimeout(() => {
          uni.createSelectorQuery().in(this).select(`.roll`).boundingClientRect(res => {
               uni.pageScrollTo({
                   //过渡时间必须为0,uniapp bug,否则运行到手机会报错
                   duration:0,
                   //滚动到实际距离是元素距离顶部的距离减去最外层盒子的滚动距离
                   scrollTop:res.top,
               })
           }).exec();
       }, 100);
});

  

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值