css锚点定位偏移原理兼容浏览器

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

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

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

function runCode(obj) { var code = obj.value; var newwin = window.open("", "", ""); newwin.opener = null; newwin.document.write(code); newwin.document.close(); }

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>锚点位置偏移</title> <style> body,h2,p{ margin:0; padding:0; } h2,p{ width:500px; position:relative; } p{ height:400px; background:#CCC; z-index:2; } p.extra{ margin:0 0 500px; } h2{ margin:-200px 0 0; border-top:200px solid #000; z-index:1; background:#06F; } #anchor1{ margin:0; } span{ position:fixed !important; position:absolute; top:200px; left:510px; } #menu{ background:#CCC; position:fixed !important; position:absolute;left:510px; top:2px; } </style> </head> <body> <h2 id="anchor1">锚点111111111111111111111</h2> <p>有一定高度的层</p> <h2 id="anchor2">锚点222222222222222222222</h2> <p>有一定高度的层</p> <h2 id="anchor3">锚点333333333333333333333</h2> <p>有一定高度的层</p> <h2 id="anchor4">锚点444444444444444444444</h2> <p>有一定高度的层</p> <h2 id="anchor5">锚点555555555555555555555</h2> <p class="extra">底端需要一定高度才可以保证滚动条有足够高度让标题5到达指定位置</p> <div 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></div> <span>&larr;目标在这里</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代码:



bodyh2p0;padding0;



h2p;position;

p;background;z-index;

p.extra

	0 0 ;



h2

	 0 0;

	  ;

	;

	;





	0;



span !important; ;top;left;

 ;  !important; ;left; ; 

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值