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插件FusionCharts绘制的3D环饼图效果示例【附demo源码】
Apr 02 jQuery
jQuery Plupload上传插件的使用
Apr 19 jQuery
JS/jquery实现一个网页内同时调用多个倒计时的方法
Apr 27 jQuery
jQuery Validate 校验多个相同name的方法
May 18 jQuery
jQuery实现点击下拉框中的值累加到文本框中的方法示例
Oct 28 jQuery
jquery手机触屏滑动拼音字母城市选择器的实例代码
Dec 11 jQuery
轻松搞定jQuery+JSONP跨域请求的解决方案
Mar 06 jQuery
jQuery使用each遍历循环的方法
Sep 19 jQuery
jQuery子选择器与可见性选择器实例分析
Jun 28 jQuery
jquery获取并修改触发事件的DOM元素示例【基于target 属性】
Oct 10 jQuery
JQuery插件tablesorter表格排序实现过程解析
May 28 jQuery
如何使用jQuery操作Cookies方法解析
Sep 08 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解答方法
2012/02/04 PHP
探讨PHP函数ip2long转换IP时数值太大产生负数的解决方法
2013/06/06 PHP
探讨:parse url解析URL,返回其组成部分
2013/06/14 PHP
PHP中unset,array_splice删除数组中元素的区别
2014/07/28 PHP
php实现的递归提成方案实例
2015/11/14 PHP
thinkPHP2.1自定义标签库的导入方法详解
2016/07/20 PHP
实例讲解YII2中多表关联的使用方法
2017/07/21 PHP
css3实现背景模糊的三种方式
2021/03/09 HTML / CSS
SyntaxHighlighter代码加色使用方法
2008/09/07 Javascript
js本身的局限性 别让javascript做太多事
2010/03/23 Javascript
jQuery easyui datagrid动态查询数据实例讲解
2013/02/26 Javascript
引入JS文件IE6报语法错误或缺少对象问题的解决方法
2014/01/09 Javascript
JavaScript里实用的原生API汇总
2015/05/14 Javascript
AngularJS学习笔记之基本指令(init、repeat)
2015/06/16 Javascript
angularjs之$timeout指令详解
2017/06/13 Javascript
基于jQuery实现的Ajax 验证用户名唯一性实例代码
2017/06/28 jQuery
JavaScript编写棋盘覆盖代码详解
2017/08/28 Javascript
详解微信小程序实现WebSocket心跳重连
2018/07/31 Javascript
Postman的下载及安装教程详解
2018/10/16 Javascript
说说如何利用 Node.js 代理解决跨域问题
2019/04/22 Javascript
[01:16]2014DOTA2 TI专访C9战队EE:中国五强中会占三席
2014/07/10 DOTA
[49:43]VG vs FNATIC 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
从零学python系列之数据处理编程实例(二)
2014/05/22 Python
简单谈谈python中的多进程
2016/11/06 Python
Python中property属性实例解析
2018/02/10 Python
Python实现调用另一个路径下py文件中的函数方法总结
2018/06/07 Python
Keras 数据增强ImageDataGenerator多输入多输出实例
2020/07/03 Python
Pycharm Git 设置方法
2020/09/15 Python
python报错TypeError: ‘NoneType‘ object is not subscriptable的解决方法
2020/11/05 Python
欧洲最大的美妆零售网站:Feelunique
2017/01/14 全球购物
美国的Eastbay旗下的运动款子品牌:Final-Score
2018/01/01 全球购物
护士实习自我鉴定
2013/10/22 职场文书
信用社员工先进事迹材料
2014/02/04 职场文书
电工工作职责范本
2014/02/22 职场文书
房地产开发项目建议书
2014/05/16 职场文书
教师党员承诺书2015
2015/01/21 职场文书