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

Posted 铁锤妹妹@

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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失效

以上是关于uniapp 将元素滚动到指定位置的两种方法总结的主要内容,如果未能解决你的问题,请参考以下文章

uniapp页面滚动到页面可指定位置

uniapp页面滚动到页面可指定位置

selenium怎么滚动到窗口中的指定元素的位置

jQuery index() 方法的两种用法

如何通过JQuery将DIV的滚动条滚动到指定的位置

动态页面的操作(滚动屏幕到指定元素位置)和DIV滚动条滚动