Skip to content

吸顶效果的探索

最近在写一个基于Vue.js的类社区项目,需要实现某个部位吸顶的效果。即,页面往上滑动,刚好到达该部位时,该部分,固定在顶部显示。

刚开始看的一篇文章说到可以用监听元素滚动再切换样式的的方式实现,开始出来的效果自我感觉还ok,然而朋友看了之后表示老有点卡卡感觉,仔细盯着动画看了半天,确实没达到那种丝滑的感觉。当时思考了下暂未找到解决的良法,近日读headroom.js的源码时茅塞顿开,收获点在于其中CSS样式的微调。

原来大概是结合Vue的v-show属性切换元素的display为fixed/none,但就是这种频繁的切换显示隐藏造成了页面的卡顿,headroom.js是用于Jquery时代的一个元素'吸顶'插件,它直接让吸顶元素全程保持display:fixed,然后调整元素的top为负值来达到隐藏的的效果,这样实现后没有破坏页面的布局,流畅多了。

基础实现方式

1、监听滚动事件

利用VUE写一个在控制台打印当前的scrollTop,

首先,在mounted钩子中给window添加一个滚动滚动监听事件,

javascript
mounted () {
  window.addEventListener('scroll', this.handleScroll)
},

然后在方法中,添加这个handleScroll方法

javascript
handleScroll () {
  var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop
  console.log(scrollTop)
},

2、监听元素到顶部的距离 并判断滚动的距离如果大于了元素到顶部的距离时,设置searchBar为true,否则就是false

javascript
handleScroll () {
  var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop
  var offsetTop = document.querySelector('#searchBar').offsetTop
  if (scrollTop > offsetTop) {
    this.searchBarFixed = true
  } else {
    this.searchBarFixed = false
  }
},

先写一个该元素固定到顶部的样式,isFixed(less写法)

css
.searchBar{
  .isFixed{
    position:fixed;
    background-color:#Fff;
    top:0;
    z-index:999;
  }

然后将需要固定的元素的class与searchBar进行绑定,如果searchBar为true时,就应用这个isFixed样式

html
<div class="searchBar" id="searchBar">
  <ul :class="searchBarFixed == true ? 'isFixed' :''">
    <li>更多<i class="iconfont icon"></i></li>
  </ul>
</div>

注意,如果离开该页面需要移除这个监听的事件,不然会报错。

javascript
destroyed () {
  window.removeEventListener('scroll', this.handleScroll)
},

顶部自动固定效果

未完待续......