小程序
小游戏
企业微信
微信支付
扫描小程序码分享
我要监听但scroll-view滚动结束后执行事件,比如我手指滑动一下停止滚动条后执行事件,求帮助?
5 个回答
加粗
标红
插入代码
插入链接
插入图片
上传视频
<scroll-view @touchend="touchend" @scroll="onScroll"></scroll-view> // js onScroll = debounce(function(event){ console.log('onScroll',this.isTouchEnd); if(this.isTouchEnd){ this.isTouchEnd = false } },500) touchend(){ this.isTouchEnd = true } // 滚动的时候就可以判断当前时候是滚动结束【基本的滑动除刁钻滚动】
你好,麻烦通过点击下方“反馈信息”按钮,提供出现问题的。
也遇到了同样的问题,而且目前似乎这能用setTimeout实现,感觉scroll-view有太多的坑。
楼主请问一下,我现在有和你一样的需求,但是呢,在setTimeOut()里面有一个that.setData(),然后就发现这个定时器好像出问题了似的,滚动结束后会执行好多次。是因为setData也是异步操作的缘故嘛??我应该怎么解决这个问题??可以指点一下嘛?
var that = this;
clearTimeout(scrollTime2);
scrollTime2 = setTimeout(function(){
console.log(n)
var scrollT = n * (itemH + 20);
that.setData({
scrollT: scrollT,
})
},100)
这里面没有滚动结束事件
无法监听,目前来讲最好的方法是在 bindscroll里 clearTimeout + setTimeout来模拟
对的,我现在就是这样做的
对的,我现在就是这样做的,但是效果不是太好
能描述下你的页面吗
关注后,可在微信内接收相应的重要提醒。
请使用微信扫描二维码关注 “微信开放社区” 公众号
<scroll-view @touchend="touchend" @scroll="onScroll"></scroll-view> // js onScroll = debounce(function(event){ console.log('onScroll',this.isTouchEnd); if(this.isTouchEnd){ this.isTouchEnd = false } },500) touchend(){ this.isTouchEnd = true } // 滚动的时候就可以判断当前时候是滚动结束【基本的滑动除刁钻滚动】
也遇到了同样的问题,而且目前似乎这能用setTimeout实现,感觉scroll-view有太多的坑。
楼主请问一下,我现在有和你一样的需求,但是呢,在setTimeOut()里面有一个that.setData(),然后就发现这个定时器好像出问题了似的,滚动结束后会执行好多次。是因为setData也是异步操作的缘故嘛??我应该怎么解决这个问题??可以指点一下嘛?
var that = this;
clearTimeout(scrollTime2);
scrollTime2 = setTimeout(function(){
console.log(n)
var scrollT = n * (itemH + 20);
that.setData({
scrollT: scrollT,
})
},100)
这里面没有滚动结束事件
无法监听,目前来讲最好的方法是在 bindscroll里 clearTimeout + setTimeout来模拟
对的,我现在就是这样做的
对的,我现在就是这样做的,但是效果不是太好
能描述下你的页面吗