本文实例为大家分享了vue实现滑动时顶部悬浮固定效果的具体代码,供大家参考,具体内容如下
这个效果是一个项目中抽出来的一个demo效果。
前期准备:
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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- Vue.js鼠标悬浮更换图片功能
- Webpack实现按需打包Lodash的几种方法详解
- JavaScript lodash常见用法系列小结
- vue移动UI框架滑动加载数据的方法
- 写一个移动端惯性滑动&回弹Vue导航栏组件 ly-tab
- vue 路由页面之间实现用手指进行滑动的方法
- vue2.0 better-scroll 实现移动端滑动的示例代码
- 基于Vue实现页面切换左右滑动效果
- vue loadmore 组件滑动加载更多源码解析
- vue实现一个移动端屏蔽滑动的遮罩层实例