vue 吸顶效果

本文介绍如何在Vue项目中实现一个div元素在页面滚动到一定位置时变为固定定位,从而达到吸顶效果。主要涉及Vue的数据绑定、事件监听以及CSS样式调整。通过监听滚动事件,动态设置class,当滚动超过特定距离时,将div设置为fixed定位,实现导航栏的吸顶功能。

1、主要的是class名,根据判断选择样式

<div id="div">
    <div :class="isFixed?'isfixed':'nav'">
        需要吸顶的div
    </div>
</div>

2、在mounted中添加滚动事件

data(){
    return {
        isfixed:false
    }
},
mountes(){
    window.addEventListener("scroll",this.getScroll,true)
}

3、监听滚动

methods:{
    getScroll(){
        const top=document.getElementById("app").scrollTop;//滚动条距离顶部的距离
        const heightOffset=document.getElementById("div").offsetHeight;//div的高度
        if(top>110 && TOP<heightOffset){
            this.isFixed=true
        }else{
            this.isFixed=false
        }
    }
}

4、css样式

.nav{
    border:solid 1px #ccc;
}
.isFixed{
    position:fixed;
    top:80px;
    left:150px;
    z-index:9999;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值