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实现 RadioButton做必选校验功能
Jun 15 jQuery
jQuery dateRangePicker插件使用方法详解
Jul 28 jQuery
jquery+css实现简单的图片轮播效果
Aug 07 jQuery
jquery中ajax请求后台数据成功后既不执行success也不执行error的完美解决方法
Dec 24 jQuery
(模仿京东用户注册)用JQuery实现简单表单验证,初学者必看
Jan 08 jQuery
jQuery中复合选择器简单用法示例
Mar 31 jQuery
关于jquery中attr()和prop()方法的区别
May 28 jQuery
jQuery实现菜单的显示和隐藏功能示例
Jul 24 jQuery
基于jquery实现九宫格拼图小游戏
Nov 30 jQuery
jQuery实现input[type=file]多图预览上传删除等功能
Aug 02 jQuery
JS JQuery获取data-*属性值方法解析
Sep 01 jQuery
JQuery基于FormData异步提交数据文件
Sep 01 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下HTTP Response中的Chunked编码实现方法
2008/11/19 PHP
PHP将XML转数组过程详解
2013/11/13 PHP
PHP程序员必须清楚的问题汇总
2014/12/18 PHP
win7系统配置php+Apache+mysql环境的方法
2015/08/21 PHP
php如何计算两坐标点之间的距离
2018/12/29 PHP
Laravel框架实现的批量删除功能示例
2019/01/16 PHP
thinkPHP3.2使用RBAC实现权限管理的实现
2019/08/27 PHP
document.getElementBy(&quot;id&quot;)与$(&quot;#id&quot;)有什么区别
2013/09/22 Javascript
javascript内置对象arguments详解
2014/03/16 Javascript
jquery+javascript编写国籍控件
2015/02/12 Javascript
使用JavaScript刷新网页的方法
2015/06/04 Javascript
jQuery实现径向动画菜单效果
2015/07/17 Javascript
分享使用AngularJS创建应用的5个框架
2015/12/05 Javascript
node.js 动态执行脚本
2016/06/02 Javascript
深入理解基于vue-cli的vuex配置
2017/07/24 Javascript
Angular CLI在Angular项目中如何使用scss详解
2018/04/10 Javascript
实用的Vue开发技巧
2019/05/30 Javascript
layui自定义插件citySelect实现省市区三级联动选择
2019/07/26 Javascript
python实现simhash算法实例
2014/04/25 Python
Python实现的数据结构与算法之基本搜索详解
2015/04/22 Python
python使用KNN算法手写体识别
2018/02/01 Python
Python实现TCP通信的示例代码
2019/09/09 Python
Python命令行参数解析工具 docopt 安装和应用过程详解
2019/09/26 Python
Python PyInstaller安装和使用教程详解
2020/01/08 Python
Django+python服务器部署与环境部署教程详解
2020/03/30 Python
keras的三种模型实现与区别说明
2020/07/03 Python
Pycharm Plugins加载失败问题解决方案
2020/11/28 Python
Selenium环境变量配置(火狐浏览器)及验证实现
2020/12/07 Python
全球最大的中文旅行网站:去哪儿网
2017/11/16 全球购物
澳洲在线厨具商店:Kitchen Style
2018/05/05 全球购物
家长给小学生的评语
2014/01/30 职场文书
幼儿园课题实施方案
2014/05/14 职场文书
质量安全标语
2014/06/07 职场文书
2014年安全生产责任书
2014/07/22 职场文书
外出听课学习心得体会
2016/01/15 职场文书
Python自动化爬取天眼查数据的实现
2021/06/15 Python