头部导航fixed定位后,a锚点定位有偏差(上部分被遮挡)

2024-03-04 09:40

本文主要是介绍头部导航fixed定位后,a锚点定位有偏差(上部分被遮挡),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这两天实现了一个很简单的静态页面,主要功能就是在nav中设置几个导航按钮,点击之后可以跳转到该页面中对应的地方,如下图所示:

在实现该功能的过程中遇到一个小问题:当设置完锚点,对nav进行fixed固定定位之后, 主要代码(非全部代码,读懂即可)

设置锚点:

    <a class="header-ls-item" href="#advantage" >优势</a>   /* 开始设置 */

    <div id="advantage" class="padding-common">我们的优势我们的优势.....</div>  /* 锚点 */

css:

header {  /* 固定定位 */

       position:fixed;

       top: 0;

       height: 60px;

      z-index:100;

}

发现要展示的目标区域竟然上移了!!! 如下图所示:

想了一下,其实原因很简单:

先重温一下fixed定位:对象脱离常规流,偏移定位是以窗口为参考,盒子的偏移位置不影响常规流中的任何元素,其margin不与其他任何margin折叠。当出现滚动条时,对象不会随着滚动。

分析:

我们所见的页面可不是简单的一个平面,它可是能被划分成无限层的,每层之间是平行的~~~(题外话,哈哈哈!)。

言归正传,既然被fixed的元素已经脱离文档流了,那么我们就可以理解为该元素已经不再占据文档中的位置了(它已飞起),那么在它之后的元素自然毫不客气的占据了它的位置,所以当我们设置的锚点滚动上来的时候,就把nav的位置占据了,也导致了我们所看到的位置向上偏移的现象。

解决方案:

当锚点被召唤的时候,告诉它此地被占,留点地儿就好了~

<a class="header-ls-item" href="#advantage" >优势</a>   /* 开始设置 */

// <div id="advantage" class="padding-common">我们的优势我们的优势.....</div>  /* 锚点 */

<a name="advantage" class="target-fix"></a>

css:

.target-fix {  // 让它滚动上来的时候在实际位置的基础上向下偏移60px,和你设置的nav高度一致即可;

   position: relative;

   top: -60px; // 偏移值

   display: block;

   height: 0;  

   overflow: hidden; //不让它展示哈~

}

大功告成,就是这么优秀!!(看了其他的文章,说这个其实本名叫“暗锚”,好高大上的名字~)

 

这篇关于头部导航fixed定位后,a锚点定位有偏差(上部分被遮挡)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/772774

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

Python程序的文件头部声明小结

《Python程序的文件头部声明小结》在Python文件的顶部声明编码通常是必须的,尤其是在处理非ASCII字符时,下面就来介绍一下两种头部文件声明,具有一定的参考价值,感兴趣的可以了解一下... 目录一、# coding=utf-8二、#!/usr/bin/env python三、运行Python程序四、

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

无人叉车3d激光slam多房间建图定位异常处理方案-墙体画线地图切分方案

墙体画线地图切分方案 针对问题:墙体两侧特征混淆误匹配,导致建图和定位偏差,表现为过门跳变、外月台走歪等 ·解决思路:预期的根治方案IGICP需要较长时间完成上线,先使用切分地图的工程化方案,即墙体两侧切分为不同地图,在某一侧只使用该侧地图进行定位 方案思路 切分原理:切分地图基于关键帧位置,而非点云。 理论基础:光照是直线的,一帧点云必定只能照射到墙的一侧,无法同时照到两侧实践考虑:关

poj 2976 分数规划二分贪心(部分对总体的贡献度) poj 3111

poj 2976: 题意: 在n场考试中,每场考试共有b题,答对的题目有a题。 允许去掉k场考试,求能达到的最高正确率是多少。 解析: 假设已知准确率为x,则每场考试对于准确率的贡献值为: a - b * x,将贡献值大的排序排在前面舍弃掉后k个。 然后二分x就行了。 代码: #include <iostream>#include <cstdio>#incl

笔记整理—内核!启动!—kernel部分(2)从汇编阶段到start_kernel

kernel起始与ENTRY(stext),和uboot一样,都是从汇编阶段开始的,因为对于kernel而言,还没进行栈的维护,所以无法使用c语言。_HEAD定义了后面代码属于段名为.head .text的段。         内核起始部分代码被解压代码调用,前面关于uboot的文章中有提到过(eg:zImage)。uboot启动是无条件的,只要代码的位置对,上电就工作,kern