better-scroll:重点解决移动端各种滚动场景需求的插件

pvwmjhxb 6年前
   <h2>better-scroll 是什么</h2>    <p>better-scroll 是一款重点解决移动端(未来可能会考虑 PC 端)各种滚动场景需求的插件。它的核心是借鉴的 <a href="/misc/goto?guid=4959615967403153652" rel="nofollow,noindex">iscroll</a> 的实现,它的 API 设计基本兼容 iscroll,在 iscroll 的基础上又扩展了一些 feature 以及做了一些性能优化。</p>    <p>better-scroll 是基于原生 JS 实现的,不依赖任何框架。它编译后的代码大小是 46kb,压缩后是 26kb,gzip 后仅有 7kb,是一款非常轻量的 JS lib。</p>    <h2>起步</h2>    <p>学习使用 better-scroll 最好的方式是看它的 demo 代码,我们把代码都放在了 <a href="/misc/goto?guid=4959754529616708516" rel="nofollow,noindex">example</a> 目录。由于目前最适合移动端开发的前端 mvvm 框架是 <a href="/misc/goto?guid=4958977564508786080" rel="nofollow,noindex">Vue</a> ,并且 better-scroll 可以很好的和 Vue 配合使用的,所以 demo 我都用 Vue 进行了重写。</p>    <p>better-scroll 最常见的应用场景是列表滚动,我们来看一下它的 html 结构</p>    <pre>  <div class="wrapper">    <ul class="content">      <li>...</li>      <li>...</li>      ...    </ul>    <!-- 这里可以放一些其它的 DOM,但不会影响滚动 -->  </div></pre>    <p>上面的代码中 better-scroll 是作用在外层 wrapper 容器上的,滚动的部分是 content 元素。这里要注意的是,better-scroll 只处理容器(wrapper)的第一个子元素(content)的滚动,其它的元素都会被忽略。</p>    <p>最简单的初始化代码如下:</p>    <pre>  import BScroll from 'better-scroll'  let wrapper = document.querySelector('.wrapper')  let scroll = new BScroll(wrapper)</pre>    <p>better-scroll 提供了一个类,实例化的第一个参数是一个原生的 DOM 对象。当然,如果传递的是一个字符串,better-scroll 内部会尝试调用 querySelector 去获取这个 DOM 对象,所以初始化代码也可以是这样:</p>    <pre>  import BScroll from 'better-scroll'  let scroll = new BScroll('.wrapper')</pre>    <h2>滚动原理</h2>    <p>很多人已经用过 better-scroll,我收到反馈最多的问题是:</p>    <p>better-scroll 初始化了, 但是没法滚动。</p>    <p>不能滚动是现象,我们得搞清楚这其中的根本原因。在这之前,我们先来看一下浏览器的滚动原理: 浏览器的滚动条大家都会遇到,当页面内容的高度超过视口高度的时候,会出现纵向滚动条;当页面内容的宽度超过视口宽度的时候,会出现横向滚动条。也就是当我们的视口展示不下内容的时候,会通过滚动条的方式让用户滚动屏幕看到剩余的内容。</p>    <p>better-scroll 也是一样的原理,我们可以用一张图更直观的感受一下:</p>    <p><img src="https://simg.open-open.com/show/71a1e5fbbb39fa4a99f96ecc333a1927.jpg"></p>    <p>绿色部分为 wrapper,也就是父容器,它会有 <strong>固定的高度</strong> 。黄色部分为 content,它是父容器的 <strong>第一个子元素</strong> ,它的高度会随着内容的大小而撑高。那么,当 content 的高度不超过父容器的高度,是不能滚动的,而它一旦超过了父容器的高度,我们就可以滚动内容区了,这就是 better-scroll 的滚动原理。</p>    <h2>文档</h2>    <p>访问 <a href="/misc/goto?guid=4959754529733792890" rel="nofollow,noindex">better-scroll 官方文档</a></p>    <h2>demo</h2>    <p><a href="/misc/goto?guid=4959754529807468581" rel="nofollow,noindex">体验地址</a></p>    <p>  </p>   <p> </p>    <p></p>