CSS解决链接锚点定位偏移的代码

建站知识 2021-07-03 08:42www.168986.cn长沙网站建设
那假如我现在要求这个位置不是在顶端,而是离顶端有一定距离。
先看看我实现的方法例子

提示您可以先修改部分代码再运行

这实际上是一种掩眼法,对齐的参考点还是在元素的顶端,只是我把元素的设置了特定的border-(padding-也可以,margin-不可以),锚点就可以好像真的一样偏移到目标标题文字,这样会使下来元素之间产生一段距离,那么我们只要设置其margin-为负值,而且刚好为padding-的值即可。还会产生一个问题,margin-为负数值时,会强行把元素的padding-覆盖到上一元素上面(假如你没有设置背景色是很难看出来的),那怎么办呢?很自然我们就会想到z-index的方法,单纯设置z-index没有用,要先设置其positon为relative,这样就可以了。(注意这里假如h2设置的padding-值超过了p的高度[包括border和padding]值会引起层叠问题,解决方法是一样的。)

实例css代码

复制代码
代码如下:

/初始化,使不影响判断/
body,h2,p{margin:0;padding:0;}
/因为要设置z-index需要先设置一下position/
h2,p{width:500px;position:relative;}
p{height:400px;background:#CCC;z-index:2;}
p.extra{
margin:0 0 500px;/一个p需要有一定的底端margin不然滚动条不够高度,会使达不到一个标题/
}
h2{
margin:-200px 0 0;/强行把元素位置拉回原位/
border-:200px solid #000;/改变目标元素对于锚点的基点位置,这里可以用padding-,有不一样的问题出现,都可以很简单解决,这里不详说了/
z-index:1;
background:#06F;
}
#anchor1{
margin:0;/第一个元素不应该被拉回原位/
}
span{position:fixed !important; position:absolute;:200px;left:510px;}
#menu{ background:#CCC; position:fixed !important; position:absolute;left:510px; :2px; }

有人可能会问为什么要这么麻烦?在这些元素的外面加一个父元素,然后把父元素移位不就成了么?这个确实是一个办法,假如你考虑到滚动条,你就会发现一个很难解决的问题,这里我就不介绍了。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by