提到ios系统的橡皮筋效果,作为开发者是又爱又恨,有想要这个效果又有不想要的,无奈的是却没有一个简单的开关来设置这个效果是否开启。
最近在开发小程序时也遇到有关于ios橡皮筋回弹的问题,这里分两部分(取消橡皮筋回弹效果和因为这个效果遇到的坑)和大家分享一下。
取消IOS橡皮筋回弹效果的解决方案
1) 页面无滚动区域时,可通过页面json配置文件设置disableScroll:true禁止整个页面滚动,从而取消橡皮筋效果。
{
"disableScroll":true
}
测试代码:https://github.com/YuniorZen/minicode-debug/tree/master/minicode01/pages/demo1
2) 页面有滚动区域,滚动区域通过view模拟实现,然后在页面json配置文件设置disableScroll:true禁止整个页面滚动,从而取消橡皮筋效果。
json文件配置
{
"disableScroll":true
}
view元素模拟实现滚动样式
{
height: calc(100vh - 120rpx); //高度必须是固定的值
overflow-y: auto;
}
不足之处在于view元素模拟的滚动区域滚动时不够连贯,没有scroll-view那种原生丝滑般的感觉。
测试代码:https://github.com/YuniorZen/minicode-debug/tree/master/minicode01/pages/demo2
3) 页面有滚动区域,滚动区域使用scroll-view,这时通过disableScroll则无法实现,尝试设置一下scroll-view的scroll-y="{{false}}",上拉或下拉时居然不再触发橡皮筋的回弹啦,当然滚动区域也不能滚动。
小脑袋动一动,解决方法有啦!
通过设置一个变量scrollY动态控制滚动区域的滚动从而阻止回弹。
监听bindscrolltoupper\bindscrolltolower当scroll-view区域滚动到顶部或底部时候设置scrollY:false来关闭页面滚动,从而阻止回弹。
监听bindtouchstart\bindtouchmove 当用户反方向滑动的时候设置scrollY:true,再次开启页面滚动。
wxml滚动区域属性和事件处理,具体实现请点击测试代码链接
<scroll-view scroll-y="{{scrollY}}" class="list" upper-threshold="5" lower-threshold="5"
bindscrolltoupper="bindscrolltoupper"
bindscrolltolower="bindscrolltolower"
bindtouchstart="touchstart"
bindtouchmove="touchmove">
<view class="list-item" wx:for="{{list}}" wx:key="{{index}}">{{item}}</view>
</scroll-view>
相对view模拟实现滚动区域,scroll-view滚动更丝滑,不过每次滚动到底部或顶部的时候,再反向滑动时由于再次开启scroll-view滚动会有操作卡顿的感觉,暂时没想到好的解决方法,有解决的大佬希望提供一下想法,一起学习下。
测试代码:https://github.com/YuniorZen/minicode-debug/tree/master/minicode01/pages/demo3
IOS橡皮筋效果遇到的坑
1) 操作左滑删除组件时上下移动,会触发橡皮筋效果导致页面抖动的问题
这个坑的严重程度看设计师的意愿了,反正我们团队目前是需要解决的,方案类似取消橡皮筋解决方案的第三种
在左滑的时候关闭scroll-view的滚动,取消时再次开启滚动
2) 如果页面顶部有置顶的横向滚动区域scroll-view,当页面滚动到底部时继续上拉会导致置顶头部消失,松开回弹后头部又会出现。
坑是社区里的朋友提出来的,我借了个iphone x 一预览,我嚓,还是真是个奇坑!
微信官方回复已复现正在解决中… 不想继续等下去的,暂时解决方法是
监听页面的滚动区域,当滚动到底部时设置顶部横向滚动scroll-view的scroll-x=false来解决。
写在最后
以上便是我在小程序开发中有关于ios橡皮筋回弹效果的分享,示例代码已上传github,可自行下载体验。
https://github.com/YuniorZen/minicode-debug/tree/master/minicode01
目前微信官方虽说已经着手解决(已两年)此类bug,但哪吒说 我命由我不由天,所以还是我们开发者多分享些解决方案自救来的快。
分享方案如有问题还望不吝指出,没有涉及到的坑也欢迎评论提出,一起学习和解决,后续也会基于此篇不断更新总结。
没这么复杂,根元素加上catchtouchmove="return"就可以了(PS:对cover-view无效)。觉得好用的亲们别吝啬点个赞呀~~~
web-view的回弹效果怎么去掉,有人试过吗
你这不行的啊,禁用后第一次反向滑动 没反应的,第二次才有反应
通过app.json设置disableScroll属性为true,scroll-view中设置enhanced="true" bounces="false",可以实现整体页面不回弹、内部正常滚动的效果。
"window": {
"disableScroll": true
},
<scroll-view scroll-y="true" bindscrolltolower="nextPage" enhanced="true" bounces="false">
wx:if=‘{{data.length>0}}’; enhanced=’{{true}}‘; bounces=‘{{false}}’;
第三种方法可行,但是第一次滑动时会卡顿,第二次就正常了,体验还是不行
不错。。学习了
哎!第一种不适合我,第二种没效果,第三种需要多滑一下,可恶,官方快修复
又两年过去了...
👍
不知道是不是微信又有什么变动。我下载你的代码下来后试了,第二种方法依然还是有下拉回弹的效果,方法三基本是没什么用的