vue+jquery+lodash实现滑动时顶部悬浮固定效果


Posted in jQuery onApril 28, 2018

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

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

vue+jquery+lodash实现滑动时顶部悬浮固定效果

前期准备:

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>

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

jQuery 相关文章推荐
jQuery实现鼠标经过显示动画边框特效
Mar 24 jQuery
Django1.7+JQuery+Ajax验证用户注册集成小例子
Apr 08 jQuery
jquery手机触屏滑动拼音字母城市选择器的实例代码
Dec 11 jQuery
jQuery封装animate.css的实例
Jan 04 jQuery
jQuery创建及操作xml格式数据示例
May 26 jQuery
jQuery实现ajax回调函数带入参数的方法示例
Jun 26 jQuery
Jquery遍历筛选数组的几种方法和遍历解析json对象,Map()方法详解以及数组中查询某值是否存在
Jan 18 jQuery
一文快速了解JQuery中的AJAX
May 31 jQuery
基于jquery ajax的多文件上传进度条过程解析
Sep 11 jQuery
基于JavaScript或jQuery实现网站夜间/高亮模式
May 30 jQuery
jquery实现抽奖功能
Oct 22 jQuery
使用jquery实现轮播图效果
Jan 02 jQuery
jQuery实现鼠标滑过商品小图片上显示对应大图片功能【测试可用】
Apr 27 #jQuery
jQuery实现DIV响应鼠标滑过由下向上展开效果示例【测试可用】
Apr 26 #jQuery
jQuery实现的点击标题文字切换字体效果示例【测试可用】
Apr 26 #jQuery
jQuery实现通过方向键控制div块上下左右移动的方法【测试可用】
Apr 26 #jQuery
jQuery length 和 size()区别总结
Apr 26 #jQuery
jQuery+ajax实现动态添加表格tr td功能示例
Apr 23 #jQuery
jQuery中图片展示插件highslide.js的简单dom
Apr 22 #jQuery
You might like
php中instanceof 与 is_a()区别分析
2015/03/03 PHP
PHP多进程通信-消息队列使用
2019/03/08 PHP
JavaScript Perfection kill 测试及答案
2010/03/23 Javascript
解读JavaScript代码 var ie = !-[1,] 最短的IE判定代码
2011/05/28 Javascript
利用JS延迟加载百度分享代码,提高网页速度
2013/07/01 Javascript
DOM节点删除函数removeChild()用法实例
2015/01/12 Javascript
input输入框鼠标焦点提示信息
2015/03/17 Javascript
smartcrop.js智能图片裁剪库
2015/10/14 Javascript
JS实现带提示的星级评分效果完整实例
2015/10/30 Javascript
js实现字符串和数组之间相互转换操作
2016/01/12 Javascript
使用jQuery的easydrag插件实现可拖动的DIV弹出框
2016/02/19 Javascript
js实现当鼠标移到表格上时显示这一格全部内容的代码
2016/06/12 Javascript
表单元素值获取方式js及java方式的简单实例
2016/10/15 Javascript
jQuery实现弹出窗口弹出div层的实例代码
2017/01/09 Javascript
jquery实现折叠菜单效果【推荐】
2017/03/08 Javascript
基于vue 开发中出现警告问题去除方法
2018/01/25 Javascript
使用angularjs.foreach时return的问题解决
2018/09/30 Javascript
详解可以用在VS Code中的正则表达式小技巧
2019/05/14 Javascript
微信小程序如何使用canvas二维码保存至手机相册
2019/07/15 Javascript
Ajax获取node服务器数据的完整步骤
2020/09/20 Javascript
Vue如何跨组件传递Slot的实现
2020/12/14 Vue.js
基于python中pygame模块的Linux下安装过程(详解)
2017/11/09 Python
基于Python实现定时自动给微信好友发送天气预报
2018/10/25 Python
浅谈python的dataframe与series的创建方法
2018/11/12 Python
自学python的建议和周期预算
2019/01/30 Python
浅谈Python3 numpy.ptp()最大值与最小值的差
2019/08/24 Python
PyQt5+Caffe+Opencv搭建人脸识别登录界面
2019/08/28 Python
django使用channels实现通信的示例
2020/10/19 Python
香港最新科技与优质家居产品购物网站:J SELECT
2018/08/21 全球购物
安全检查验收制度
2014/01/12 职场文书
前处理班长职位说明书
2014/03/01 职场文书
运动会宣传稿50字
2015/07/23 职场文书
有关浪费资源的建议书
2015/09/14 职场文书
python第三方网页解析器 lxml 扩展库与 xpath 的使用方法
2021/04/06 Python
Java 关于String字符串原理上的问题
2022/04/07 Java/Android
Redis官方可视化工具RedisInsight安装使用教程
2022/04/19 Redis