评论

小程序取消橡皮筋回弹效果解决方案及坑总结

分享取消橡皮筋回弹效果的解决方案和因为这个效果遇到的坑,和大家一起学习交流。

提到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,但哪吒说 我命由我不由天,所以还是我们开发者多分享些解决方案自救来的快。
分享方案如有问题还望不吝指出,没有涉及到的坑也欢迎评论提出,一起学习和解决,后续也会基于此篇不断更新总结。

最后一次编辑于  2021-01-14  
点赞 22
收藏
评论

13 个评论

  • 安静的七
    安静的七
    2020-02-18

    没这么复杂,根元素加上catchtouchmove="return"就可以了(PS:对cover-view无效)。觉得好用的亲们别吝啬点个赞呀~~~

    2020-02-18
    赞同 21
    回复 19
    • Yunior
      Yunior
      2020-02-21
      感谢反馈,空了试试
      2020-02-21
      回复
    • 97
      97
      2020-03-13
      牛逼啊哥们   真的是一句搞定  牛逼牛逼
      2020-03-13
      回复
    • 蒋志坚
      蒋志坚
      2020-03-25
      设置了之后不能滚动了
      2020-03-25
      回复
    • 陈生
      陈生
      2020-04-28
      试了,不行,按住上滑不松开又下拉,依然出现
      2020-04-28
      2
      回复
    • 2020-06-04
      感谢,加上去立马好
      2020-06-04
      回复
    查看更多(14)
  • 风车车
    风车车
    2021-04-27

    web-view的回弹效果怎么去掉,有人试过吗

    2021-04-27
    赞同 5
    回复 1
    • Johnny Lin
      Johnny Lin
      2023-12-15
      有没有好的解决办法啊大佬,我也遇到了这个问题
      2023-12-15
      回复
  • Rena🧸
    Rena🧸
    2020-04-03

    你这不行的啊,禁用后第一次反向滑动 没反应的,第二次才有反应

    2020-04-03
    赞同 2
    回复
  • Zee
    Zee
    2023-10-18

    通过app.json设置disableScroll属性为true,scroll-view中设置enhanced="true" bounces="false",可以实现整体页面不回弹、内部正常滚动的效果。

    "window": {

    "disableScroll": true

    },

    <scroll-view scroll-y="true" bindscrolltolower="nextPage" enhanced="true" bounces="false"> 

    2023-10-18
    赞同 1
    回复 1
    • 不四
      不四
      2023-11-08
      有效
      2023-11-08
      回复
  • 飞龙👨
    飞龙👨
    2023-11-22

    第三种方法可行,但是第一次滑动时会卡顿,第二次就正常了,体验还是不行

    2023-11-22
    赞同
    回复
  • Jimmy Luo
    Jimmy Luo
    2022-05-26

    给scrollView加个高度就行了

    2022-05-26
    赞同
    回复
  • 雪峰学华
    雪峰学华
    2021-10-20

    不错。。学习了

    2021-10-20
    赞同
    回复
  • 招雄彬正在输入。。
    招雄彬正在输入。。
    2021-08-13

    哎!第一种不适合我,第二种没效果,第三种需要多滑一下,可恶,官方快修复

    2021-08-13
    赞同
    回复
  • 大宝Jimmy
    大宝Jimmy
    2021-01-24

    又两年过去了...

    2021-01-24
    赞同
    回复 9
    • chove。
      chove。
      2022-01-22
      又过去一年了 难受
      2022-01-22
      回复
    • 一只猫的花园
      一只猫的花园
      2022-12-09回复chove。
      马上迎来2023年了
      2022-12-09
      回复
    • 北彼
      北彼
      2023-01-05
      又一年过去了
      2023-01-05
      回复
    • 鑫
      2023-03-22
      又一年
      2023-03-22
      回复
    • Show me your bug
      Show me your bug
      2023-03-29回复
      又一个星期
      2023-03-29
      回复
    查看更多(4)
  • 喂,Sinpo
    喂,Sinpo
    2021-01-22

    👍

    2021-01-22
    赞同
    回复

正在加载...

登录 后发表内容