使用微信小程序基础组件中的scroll-view,但是滑动的时候 bindscroll 一直不生效。
<view class="container log-list"> <scroll-view scroll-y style="height:100%;white-space:nowrap;" scroll-into-view="{{toView}}" enable-back-to-top bindscroll="scroll" scroll-with-animation scroll-top="{{scrollTop}}"> <view class="list-group" wx:for="{{logs}}" wx:for-item="group"> <view class="title" id="{{group.title}}">{{group.title}}view> <block wx:for="{{group.items}}" wx:for-item="user"> <view id="" class="list-group-item"> <image class="icon" src="{{user.avatar}}" lazy-load="true">image> <text class="log-item">{{user.name}}text> view> block> view>scroll-view>
在网上查了资料,发现了几类不生效的原因,总结如下:
没有设置高度,根据小程序文档,在使用 scroll-view 组件用于竖向滚动时一定要设置高度。
没有设定scroll-y
3、组件属性的长度单位默认为px,2.4.0起支持传入单位(rpx/px)。设定百分比高度可能不生效
4、scroll-view 里有两个子元素,加一个view给包起来
5、滚动的可能是page,如果确定page里的内容不需要滚动。只滚动scroll-view里的内容,禁用页面滚动
发现我的问题应该是第3种情况,高度设置的100%可能没生效,修改如下:
<scroll-view scroll-y style="height:100vh;white-space:nowrap;" scroll-into-view="{{toView}}" enable-back-to-top bindscroll="scroll" scroll-with-animation scroll-top="{{scrollTop}}">
测试后问题解决了,
来源地址:https://blog.csdn.net/joe0235/article/details/132562316