微信小程序如何控制滚动scroll-view按照时间滚动到指定的view的id的位置
时间: 2023-08-16 11:03:37 浏览: 139
要实现按照时间滚动到指定的view的id的位置,需要使用定时器和scrollIntoView方法结合起来。具体操作步骤如下:
1. 在需要滚动到的目标view上设置id属性。
2. 在scroll-view组件上设置scroll-into-view属性,值为目标view的id值。
3. 使用定时器,每隔一段时间(如200毫秒)将toView变量的值依次设置为目标view的id值,然后调用scroll-view组件的scrollIntoView方法,将目标view的id值作为参数传入即可。
示例代码如下:
.wxml文件:
```
<scroll-view scroll-into-view="{{toView}}" scroll-y="true">
<view id="view1">View1</view>
<view id="view2">View2</view>
<view id="view3">View3</view>
</scroll-view>
<button bindtap="scrollToView">按时间滚动到View2</button>
```
.js文件:
```
Page({
data: {
toView: '',
timeScroll: null
},
scrollToView: function () {
var toView = 'view2';
var viewIds = ['view1', 'view2', 'view3'];
var currentIndex = viewIds.indexOf(this.data.toView);
var targetIndex = viewIds.indexOf(toView);
var timeScroll = setInterval(() => {
currentIndex++;
if (currentIndex > targetIndex) {
clearInterval(this.data.timeScroll);
this.setData({
timeScroll: null
})
} else {
this.setData({
toView: viewIds[currentIndex]
})
this.selectComponent('#scroll-view').scrollIntoView(viewIds[currentIndex])
}
}, 200);
this.setData({
timeScroll: timeScroll
})
}
})
```
在上面的示例中,我们首先定义了一个toView变量,表示要滚动到的目标view的id值。然后定义了一个viewIds数组,包含所有需要滚动到的view的id值。
在scrollToView方法中,我们使用定时器,每隔200毫秒依次将toView变量的值设置为viewIds数组中的下一个id值,然后调用scrollIntoView方法将scroll-view组件滚动到对应的view上。当toView变量的值等于目标view的id值时,清除定时器,停止滚动。
需要注意的是,为了在滚动过程中能够停止定时器,我们需要将定时器的引用保存在data中,然后在定时器结束时清除引用。
阅读全文