实现头部Sticky 粘性布局,并且点击菜单滑动到相应位置

摘要:该代码实现了一个带粘性导航栏的页面滚动功能。通过el-button组件绑定点击事件,调用scrollToCity方法实现平滑滚动到对应ID的区块。使用scrollIntoViewsmooth参数实现平滑滚动效果,并通过CSS的position:sticky使导航栏固定在顶部。注意事项包括:祖先元素不能设置overflow:hidden,否则会导致粘性布局失效。导航栏设置了z-index确保始终显示在前端。

复制代码
<template>
<div>
    <div class="buildNameClass">
         <!--给导航项绑定点击事件-->
         <el-button type="primary" @click="scrollToCity('one')">工商信息</el-button>
         <el-button type="primary" @click="scrollToCity('two')">股权关系</el-button>
         <el-button type="primary" @click="scrollToCity('three')">城市布局</el-button>
         <el-button type="primary" @click="scrollToCity('four')">分支机构</el-button>
    </div>
    <div>
        <!--给目标元素加 id -->
        <div class="thirdClass" id="city-one"></div>
        <div class="eighthClass" id="city-two"></div>
        <div class="eighthClass" id="city-three"></div>
        <div class="fourthClass" id="city-four"></div>
    </div>
</div>
<template>

<script>
export default {
    methods: {
        //使用 scrollIntoView({behavior: 'smooth'}) 实现平滑滚动
        scrollToCity(cityId) {
            const element = document.getElementById(`city-${cityId}`);
            if (element) {
                element.scrollIntoView({
                    behavior: 'smooth', // 平滑滚动
                    block: 'start'       // 对齐顶部
                });
            }
        },
    }
}
</script>

<style>
    //css样式粘性布局
    //要注意相关祖先组件不能有overflow: hidden;会导致粘性布局失效
    //如果滚动是body层级控制,则要确保从 .buildNameClass 到 <body> 之间没有任何 overflow:                     hidden;
    .buildNameClass{
        width: 100%;
        height: 50px;
        margin-top: 20px;
        border-radius: 6px;
        background-color: rgba(255,255,255,0.74);
        font-size: 19px;
        font-weight: bold;
        display: flex;
        flex-direction: row;
        align-items: center;
        position: sticky;
        position: -webkit-sticky;
        top: 50px;
        z-index: 9999;
    }
</style>
相关推荐
梦帮科技18 分钟前
Node.js配置生成器CLI工具开发实战
前端·人工智能·windows·前端框架·node.js·json
VT.馒头1 小时前
【力扣】2695. 包装数组
前端·javascript·算法·leetcode·职场和发展·typescript
css趣多多1 小时前
一个UI内置组件el-scrollbar
前端·javascript·vue.js
-凌凌漆-1 小时前
【vue】pinia中的值使用 v-model绑定出现[object Object]
javascript·vue.js·ecmascript
C澒1 小时前
前端整洁架构(Clean Architecture)实战解析:从理论到 Todo 项目落地
前端·架构·系统架构·前端框架
C澒1 小时前
Remesh 框架详解:基于 CQRS 的前端领域驱动设计方案
前端·架构·前端框架·状态模式
Charlie_lll1 小时前
学习Three.js–雪花
前端·three.js
onebyte8bits2 小时前
前端国际化(i18n)体系设计与工程化落地
前端·国际化·i18n·工程化
C澒2 小时前
前端分层架构实战:DDD 与 Clean Architecture 在大型业务系统中的落地路径与项目实践
前端·架构·系统架构·前端框架
BestSongC2 小时前
行人摔倒检测系统 - 前端文档(1)
前端·人工智能·目标检测