uniapp 将元素滚动到指定位置的两种方法总结

1. 前言

大概有两种方式

1)使用 uni.pageScrollTo 方法,属于页面级别滚动。
2)使用 scroll-view 标签的属性:scroll-top(距离值 num) 或 scroll-into-view(子元素的id,不能以数字开头 string); 属于区域级别滚动。
两种方式的前提是:提供具体的高度值

2. uni.pageScrollTo 方法

将页面滚动到目标位置。

uni.pageScrollTo({
   scrollTop: 0,
   duration: 0,
})

如果传入 scrollTop 不起效,应该是布局的问题, 它是页面级的滚动:所有的 滚动单元 必须是在根元素下,由 滚动单元 直接撑起来的高度,就可以滚动到指定位置。

完整的使用方法:

<view class="index-con">
   <!-- 需要滚动的内容 放在一个根元素下 -->
</view>
 //获取元素离页面顶部的距离
    getElementScollTop() {
      const query = uni.createSelectorQuery()
      query
        .select('.index-con')
        .boundingClientRect((data) => {
          console.log(data, 'data')
          let pageScrollTop = Math.round(data.top)
          uni.pageScrollTo({
            scrollTop: pageScrollTop, //滚动的距离
            duration: 0, //过渡时间
        })
      })
        .exec()
    },

打印返回的data
在这里插入图片描述

uni.pageScrollTo官方文档
uni.createSelectorQuery()官方文档

3. scroll-view 标签方法

用于区域滚动。
在这里插入图片描述

 <scroll-view scroll-y scroll-with-animation :scroll-top="scrollTop" :style="{height: conHeight + 'px'}"></scroll-view>

使用这个没发现啥问题,直接随时修改 scrollTop 的值就可以滚动,在需要使用 scroll-view 的地方直接用。

scroll-view官方文档

可参考
uniapp 滚动到指定元素的位置 滚动到底部、顶部 uni.pageScrollTo失效

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值