虚位以待(AD)
虚位以待(AD)
首页 > 网页特效 > JavaScript > vue+jquery+lodash实现滑动时顶部悬浮固定效果

vue+jquery+lodash实现滑动时顶部悬浮固定效果
类别:JavaScript   作者:码皇   来源:互联网   点击:

这篇文章主要为大家详细介绍了vue+jquery+lodash实现滑动时顶部悬浮固定效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了vue实现滑动时顶部悬浮固定效果的具体代码,供大家参考,具体内容如下

这个效果是一个项目中抽出来的一个demo效果。

前期准备:

1. 引入jQ

    <script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.js"></script>

引入lodash.js

    npm install lodash -D

fixTop.vue组件的

    <template> <div class="fixtop2"> <header class="header" ref="header"></header> <div class="nav" ref="nav" :class="{
    isFixed:isFixed}
    "> <div class="box" v-for="(item,index) in list" :key="index"> {
    {
    item.title}
    }
    </div> </div> <ul class="content"> <li v-for="(item,index) in new Array(20)" :key="index">{
    {
    index+1}
    }
    </li> </ul> </div></template><script>var throttle = require('lodash/throttle');
    //从lodash中引入的throttle节流函数export default {
    name: 'navScroll2', data() {
    return {
    list: [ {
    title: 'AAAA', id: 1 }
    , {
    title: 'BBBB', id: 2 }
    , {
    title: 'CCCC', id: 3 }
    , {
    title: 'DDDD', id: 4 }
    , ], isFixed: false, //是否固定的 throttleScroll: null, //定义一个截流函数的变量 }
    ;
    }
    , methods: {
    //滚动的函数 handleScroll() {
    let h = $(this.$refs.header).outerHeight();
    //header的高度 let wh = $(window).scrollTop();
    //滚动的距离的,为什么这里使用的jq,因为不用考虑的什么的兼容问题 let navH = $(this.$refs.nav).outerHeight();
    //nav的高度 if (wh > h) {
    this.isFixed = true;
    }
    else {
    this.isFixed = false;
    }
    }
    , }
    , mounted() {
    //写在掉接口的里面的 this.$nextTick(() => {
    //这里使用监听的scroll的事件,为什么要使用的节流函数,如果不使用的,页面一直在滚动计算的,这样在 //使用手机时候,出现非常卡的,隔一段时间计算,大大降低了性能的消耗(具体的好处自己去查资料) window.addEventListener('scroll', this.throttleScroll, false);
    }
    );
    this.throttleScroll = throttle(this.handleScroll, 100);
    }
    , deactivated() {
    //离开页面需要remove这个监听器,不然还是卡到爆。 window.removeEventListener('scroll', this.throttleScroll);
    }
    ,}
    ;
    </script><style lang="scss" scoped>.fixtop2 {
    min-height: 100vh;
    }
    .header {
    height: 5rem;
    width: 100%;
    background-color: red;
    }
    .nav {
    display: flex;
    width: 100%;
    background-color: pink;
    &.isFixed {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 9999;
    }
    .box {
    font-size: 0.3rem;
    padding: 0 0.3rem;
    height: 0.9rem;
    line-height: 0.9rem;
    color: #333333;
    flex: 1;
    }
    }
    .content {
    height: 20rem;
    li {
    width: 100%;
    height: 1rem;
    border-bottom: 1px solid #000;
    }
    }
    </style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

  • Vue.js鼠标悬浮更换图片功能
  • Webpack实现按需打包Lodash的几种方法详解
  • JavaScript lodash常见用法系列小结
  • vue移动UI框架滑动加载数据的方法
  • 写一个移动端惯性滑动&回弹Vue导航栏组件 ly-tab
  • vue 路由页面之间实现用手指进行滑动的方法
  • vue2.0 better-scroll 实现移动端滑动的示例代码
  • 基于Vue实现页面切换左右滑动效果
  • vue loadmore 组件滑动加载更多源码解析
  • vue实现一个移动端屏蔽滑动的遮罩层实例
相关热词搜索: vue滑动顶部悬浮固定 vue顶部悬浮固定 vue