1: 为什么要使用 better-scroll ?
data:image/s3,"s3://crabby-images/623a8/623a85a074a4aa83edc24e15fdc493ac246a73af" alt=""
解:(1)体验像原生:滚动非常流畅,而且没有滚动条。
(2)BetterScroll 是一款重点解决移动端各种滚动场景需求的开源插件。有下列功能支持滚动列表,下拉刷新,上拉刷新,轮播图,slider等功能。
2: 我们学习它,想要达到什么样目的?
解:能够在项目中的实现列表、弹出框滚动效果等等。
data:image/s3,"s3://crabby-images/8d2d7/8d2d72d181c512a2e84e6037de50215c52e8c5f6" alt=""
3: 那我们学习过程中注意什么?
解:这个就是我想跟大家讲的几个易错点,希望可以节约大家找问题的时间,快速找到问题。
易错点,快速定位问题:
html 结构:外层 .list-wrappe 包裹 内层 info-list , 里面只有一个子元素。
data:image/s3,"s3://crabby-images/f8088/f8088d405c611e10ecacffb1bdb95ebf5cb78645" alt=""
css代码:外层.list-wrappe 如果是横向滚动就要限制宽度,垂直滚动就要限制高度,然后overflow: hidden.
data:image/s3,"s3://crabby-images/95739/95739454ce201a6108bc89f4028d9b1a2096386a" alt=""
js 代码部分
data:image/s3,"s3://crabby-images/79c87/79c873128c033cfd2711845b34d15e1a1bbf274e" alt=""
初始化问题:检查上面的相关设置是否已做好,初始化会在内层即滚动层进行滚动的相关的style设置
data:image/s3,"s3://crabby-images/4450d/4450d401a0bd551a63100566541f23c634253ec6" alt=""
初始化成功了,还不能滚动。考虑计算高度出错,检查内层高度是否大于外层高度。 打印better-scroll对象,看字段 hasVerticalScroll:true , scrollHeight 值是否大于wrapperHeight .
data:image/s3,"s3://crabby-images/fb094/fb09486e8b5c6a19dc78b357b593a4549004c6d9" alt=""
data:image/s3,"s3://crabby-images/667cd/667cd2257fd7283dc50a84c0902f208379566b7d" alt=""
计算高度错误一般出现加载的时机不对:
(1)一般在接口获取完数据进行初始化。
(2)等图片加载完成,才进行初始化。
data:image/s3,"s3://crabby-images/03c63/03c63249e97fa1041294de91eb9e9cd0905ae82f" alt=""
data:image/s3,"s3://crabby-images/e3897/e3897d0056b2d4184fa40e7463ae47f2c17d37a1" alt=""
data:image/s3,"s3://crabby-images/a2158/a215898966ea864b2e965914639ea3c2526299a3" alt=""
6:之前项目想实现弹出框,弹出框里面有一层进行滚动。实现上面两个都没问题,但是不能滚动。花了两天时间,查找问题。原来不在这个身上。而是弹出框的组件上设置了 touchmove事件,设置了preventDefault()。
touchmove事件:当手指在屏幕上滑动的时候连续地触发。在这个事件发生期间,调用preventDefault()事件可以阻止滚动。
网友评论