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实现简单实用的轮播器
May 23 jQuery
jQuery.Form实现Ajax上传文件同时设置headers的方法
Jun 26 jQuery
jQuery列表检索功能实现代码
Jul 17 jQuery
jQuery实现火车票买票城市选择切换功能
Sep 15 jQuery
jQuery中库的引用方法
Jan 06 jQuery
jquery+css3实现熊猫tv导航代码分享
Feb 12 jQuery
jQuery动态移除与增加onclick属性的方法详解
Jun 07 jQuery
jQuery实现获取当前鼠标位置并输出功能示例
Jan 05 jQuery
JQuery判断radio单选框是否选中并获取值的方法
Jan 17 jQuery
jQuery实现当拉动滚动条到底部加载数据的方法分析
Jan 24 jQuery
jQuery zTree插件使用简单教程
Aug 16 jQuery
JQuery使用属性addClass、removeClass和toggleClass实现增加和删除类操作示例
Nov 18 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弹出对话框实现重定向代码
2014/01/23 PHP
PHP中使用sleep造成mysql读取失败的案例和解决方法
2014/08/21 PHP
php生成随机数的三种方法
2014/09/10 PHP
smarty内置函数config_load用法实例
2015/01/22 PHP
PHP实现批量检测网站是否能够正常打开的方法
2016/08/23 PHP
Laravel5.* 打印出执行的sql语句的方法
2017/07/24 PHP
如何通过Apache在本地配置多个虚拟主机
2020/07/29 PHP
javascript写的一个链表实现代码
2009/10/25 Javascript
通过javascript获取iframe里的值示例代码
2013/06/24 Javascript
javascript实现简单的鼠标拖动效果实例
2015/04/10 Javascript
由简入繁实现Jquery树状结构的方法(推荐)
2016/06/10 Javascript
基于rem的移动端响应式适配方案(详解)
2017/07/07 Javascript
详解Angular5 路由传参的3种方法
2018/04/28 Javascript
vue的for循环使用方法
2019/02/12 Javascript
一文快速了解JQuery中的AJAX
2019/05/31 jQuery
js实现固定区域内的不重叠随机圆
2019/10/24 Javascript
如何使用vue slot创建一个模态框的实例代码
2020/05/24 Javascript
jQuery+ThinkPHP实现图片上传
2020/07/23 jQuery
[01:06]DOTA2亚洲邀请赛专属珍藏-荧煌之礼
2017/03/24 DOTA
python实现根据用户输入从电影网站获取影片信息的方法
2015/04/07 Python
Python实现FTP上传文件或文件夹实例(递归)
2017/01/16 Python
深入理解Python中的*重复运算符
2017/10/28 Python
python用pandas数据加载、存储与文件格式的实例
2018/12/07 Python
django项目中新增app的2种实现方法
2020/04/01 Python
使用SimpleITK读取和保存NIfTI/DICOM文件实例
2020/07/01 Python
基于第一个PhoneGap(cordova)的应用详解
2013/05/03 HTML / CSS
台湾演唱会订票网站:StubHub台湾
2019/06/11 全球购物
Onzie官网:美国时尚瑜伽品牌
2019/08/21 全球购物
Ajax和javascript的区别
2013/07/20 面试题
应届生法律顾问求职信
2013/11/19 职场文书
银行员工职业规划范文
2014/01/21 职场文书
大学毕业自我鉴定范文
2014/02/03 职场文书
个人担保书格式范文
2014/05/12 职场文书
毕业生学校推荐信范文
2014/05/21 职场文书
投标承诺函范文
2015/01/21 职场文书
HTML5来实现本地文件读取和写入的实现方法
2021/05/25 HTML / CSS