头部导航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

相关文章

无人叉车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

js定位navigator.geolocation

一、简介   html5为window.navigator提供了geolocation属性,用于获取基于浏览器的当前用户地理位置。   window.navigator.geolocation提供了3个方法分别是: void getCurrentPosition(onSuccess,onError,options);//获取用户当前位置int watchCurrentPosition(

项目实战系列三: 家居购项目 第四部分

购物车 🌳购物车🍆显示购物车🍆更改商品数量🍆清空购物车&&删除商品 🌳生成订单 🌳购物车 需求分析 1.会员登陆后, 可以添加家居到购物车 2.完成购物车的设计和实现 3.每添加一个家居,购物车的数量+1, 并显示 程序框架图 1.新建src/com/zzw/furns/entity/CartItem.java, CartItem-家居项模型 /***

码蹄集部分题目(2024OJ赛9.4-9.8;线段树+树状数组)

1🐋🐋配对最小值(王者;树状数组) 时间限制:1秒 占用内存:64M 🐟题目思路 MT3065 配对最小值_哔哩哔哩_bilibili 🐟代码 #include<bits/stdc++.h> using namespace std;const int N=1e5+7;int a[N],b[N],c[N],n,q;struct QUERY{int l,r,id;}que

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位

flume系列之:记录一次flume agent进程被异常oom kill -9的原因定位 一、背景二、定位问题三、解决方法 一、背景 flume系列之:定位flume没有关闭某个时间点生成的tmp文件的原因,并制定解决方案在博主上面这篇文章的基础上,在机器内存、cpu资源、flume agent资源都足够的情况下,flume agent又出现了tmp文件无法关闭的情况 二、

关于断言的部分用法

1、带变量的断言  systemVerilog assertion 中variable delay的使用,##[variable],带变量的延时(可变延时)_assertion中的延时-CSDN博客 2、until 的使用 systemVerilog assertion 中until的使用_verilog until-CSDN博客 3、throughout的使用   常用于断言和假设中的

牛客小白月赛100部分题解

比赛地址:牛客小白月赛100_ACM/NOI/CSP/CCPC/ICPC算法编程高难度练习赛_牛客竞赛OJ A.ACM中的A题 #include<bits/stdc++.h>using namespace std;#define ll long long#define ull = unsigned long longvoid solve() {ll a,b,c;cin>>a>>b>

YOLOv8改进实战 | 注意力篇 | 引入CVPR2024 PKINet 上下文锚点注意力CAAttention

YOLOv8专栏导航:点击此处跳转 前言 YOLOv8 是由 YOLOv5 的发布者 Ultralytics 发布的最新版本的 YOLO。它可用于对象检测、分割、分类任务以及大型数据集的学习,并且可以在包括 CPU 和 GPU 在内的各种硬件上执行。 YOLOv8 是一种尖端的、最先进的 (SOTA) 模型,它建立在以前成功的 YOLO 版本的基础上,并引入了新的功能和改进,以