vue 滑动置顶功能_VUE 实现滚动监听 导航栏置顶的方法_蜡烛_前端开发者

非重点的代码,比如样式啥的,我就不放上来了,一笔带过

简略的写一下

1. data ()

data () {

paddingBottom: '1.5rem', // 给最外层div一个padding-bottom

// 因为footer是fixed定位 如果padding-bottom为0 数据列表拉到最下面的时候 会有部分数据被footer挡住

isFixed: false, // bar浮动

offsetTop: 0, // 触发bar浮动的阈值

marginTop: 0, // 触发bar浮动的同时 给数据列表一个margin-top 防止列表突然上移 会很突兀

advertShow: true, // 广告显示

}

2. mounted ()

mounted () {

// 设置初始的 padding-bottom 值为 footer 的高度 +20 防止数据列表拉到最下面被footer挡住 +多少自定

this.paddingBottom = document.querySelector('.footer').offsetHeight + 20 + 'px';

// 设置bar浮动阈值为 #fixedBar 至页面顶部的距离

this.offsetTop = document.querySelector('#fixedBar').offsetTop;

// 开启滚动监听

window.addEventListener('scroll', this.handleScroll);

}

3. methods

methods: {

// 关闭广告

del () {

this.advertShow = true;

this.$nextTick(() => {

this.paddingBottom = document.querySelector('.footer').offsetHeight + 20 + 'px';

});

},

// 滚动监听 滚动触发的效果写在这里

handleScroll () {

var scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop;

if (scrollTop >= this.offsetTop) {

this.isFixed = true;

this.marginTop = document.querySelector('#fixedBar').offsetHeight + 'px';

} else {

this.isFixed = false;

this.marginTop = 0;

}

}

}

4. destroyed ()

destroyed () {

window.removeEventListener('scroll', this.handleScroll); // 离开页面 关闭监听 不然会报错

}

效果图

以上这篇开发者。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值