[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代码:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)bodyh2p{margin:0;padding0;h2p{width:500px;position:relative;p{height:400px;background:#CCC;z-index:2;p.extramargin:0 0 ;h2margin:-200px 0 0;border-top:200px ;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;
有人可能会问为什么要这么麻烦?在这些元素的外面加一个父元素,然后把父元素移位不就成了么?这个确实是一个办法,但是假如你考虑到滚动条,你就会发现一个很难解决的问题,这里我就不介绍了。