2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > CSS解决链接锚点定位偏移

CSS解决链接锚点定位偏移

时间:2018-12-18 05:50:51

相关推荐

CSS解决链接锚点定位偏移

今天给大家分享的是由小编精心为您推荐的CSS解决链接锚点定位偏移,喜欢的朋友可以分享一下,也算是给小编一份支持,大家都不容易啊!

不知道有没有人研究过这个,当点击页面的锚点连接的时候一般就跳转到特定id的元素,而实际表现的是滚动条滚动使该特定id元素对齐滚动条所处元素的顶端。

那假如我现在要求这个位置不是在顶端,而是离顶端有一定距离。

先看看我实现的方法例子:

!DOCTYPE html PUBLIC "-//W3C//DTDXHTML1.0 Transitional//EN" "& xmlns="& http-equiv="Content-Type" content="text/html; charset=utf-8" /title锚点位置偏移/titlestylebody,h2,p{},{}{#}{ 0 500px;}h2{margin:-200px 0 0; solid #000;#}#{}{ !important; }#{ background:#CCC; !important; ; ; }/style/headbodyh2 id="anchor1"锚点111111111111111111111/h2p有一定高度的层/ph2 id="anchor2"锚点222222222222222222222/h2p有一定高度的层/ph2 id="anchor3"锚点333333333333333333333/h2p有一定高度的层/ph2 id="anchor4"锚点444444444444444444444/h2p有一定高度的层/ph2 id="anchor5"锚点555555555555555555555/h2p class="extra"底端需要一定高度才可以保证滚动条有足够高度让标题5到达指定位置/pdiv id="menu"a href="#anchor1"去往锚点1/a a href="#anchor2"去往锚点2/a a href="#anchor3"去往锚点3/a a href="#anchor4"去往锚点4/a a href="#anchor5"去往锚点5/a/divspan←目标在这里/span/body/html

[Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

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

实例css代码:

bodyh2p{{{# 0 ;h2margin:-200px 0 0; ;z-index:1;background:#06F;#anchor1{margin:0;span{ !important; #{ background:#CCC; !important; ; ;

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。