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 23 jQuery
jQuery EasyUI 为Combo,Combobox添加清除值功能的实例
Apr 13 jQuery
jQuery插件FusionCharts绘制的3D双柱状图效果示例【附demo源码】
Apr 20 jQuery
jquery中封装函数传递当前元素的方法示例
May 05 jQuery
简单实现jQuery弹幕效果
May 06 jQuery
jQuery日期范围选择器附源码下载
May 23 jQuery
深入理解jquery的$.extend()、$.fn和$.fn.extend()
Jul 08 jQuery
jQuery实现菜单栏导航效果
Aug 15 jQuery
jQuery NProgress.js加载进度插件的简单使用方法
Jan 31 jQuery
用jQuery将JavaScript对象转换为querystring查询字符串的方法
Nov 12 jQuery
超好用的jQuery分页插件jpaginate用法示例【附源码下载】
Dec 06 jQuery
JavaScript表格隔行变色和Tab标签页特效示例【附jQuery版】
Jul 11 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 获取文件权限函数介绍
2013/07/11 PHP
Zend studio文件注释模板设置方法
2013/09/29 PHP
PHP小技巧之JS和CSS优化工具Minify的使用方法
2014/05/19 PHP
php实现通用的从数据库表读取数据到数组的函数实例
2015/03/21 PHP
PHP中substr_count()函数获取子字符串出现次数的方法
2016/01/07 PHP
PHP实现的简单对称加密与解密方法实例小结
2017/08/28 PHP
Jquery在IE7下无法使用 $.ajax解决方法
2009/11/11 Javascript
input 和 textarea 输入框最大文字限制的jquery插件
2011/10/27 Javascript
js判断是否为数组的函数: isArray()
2011/10/30 Javascript
jquery 选择器引擎sizzle浅析
2013/02/06 Javascript
把文本中的URL地址转换为可点击链接的JavaScript、PHP自定义函数
2014/07/29 Javascript
javascript学习笔记(六)数据类型和JSON格式
2014/10/08 Javascript
在Python中使用glob模块查找文件路径的方法
2015/06/17 Javascript
jQuery实现发送验证码并60秒倒计时功能
2016/11/25 Javascript
JSONP跨域请求
2017/03/02 Javascript
微信小程序实现分享到朋友圈功能
2018/07/19 Javascript
js使用Promise实现简单的Ajax缓存
2018/11/14 Javascript
vscode vue 文件模板的配置方法
2019/07/23 Javascript
python回溯法实现数组全排列输出实例分析
2015/03/17 Python
Python生成器(Generator)详解
2015/04/13 Python
python实现数据图表
2017/07/29 Python
python 实现将字典dict、列表list中的中文正常显示方法
2018/07/06 Python
基于python实现学生管理系统
2018/10/17 Python
详解Python函数式编程—高阶函数
2019/03/29 Python
python字符串拼接+和join的区别详解
2020/12/03 Python
做一个能自适应高度的textarea的示例代码
2019/09/06 HTML / CSS
Old Navy加拿大官网:美式休闲服饰品牌
2017/09/26 全球购物
Java程序员面试题
2013/07/15 面试题
自我评价范文点评
2013/12/04 职场文书
公司成立感言
2014/01/11 职场文书
英语系毕业生求职信
2014/07/13 职场文书
2014年档案管理员工作总结
2014/12/01 职场文书
计划生育汇报材料
2014/12/26 职场文书
2015年老干部工作总结
2015/04/23 职场文书
2015年教师师德师风承诺书
2015/04/28 职场文书
如何在C++中调用Python
2021/05/21 Python