文章导航PC6首页软件下载单机游戏安卓资源苹果资源

pc软件新闻网络操作系统办公工具编程服务器软件评测

安卓新闻资讯应用教程刷机教程安卓游戏攻略tv资讯深度阅读综合安卓评测

苹果ios资讯苹果手机越狱备份教程美化教程ios软件教程mac教程

单机游戏角色扮演即时战略动作射击棋牌游戏体育竞技模拟经营其它游戏游戏工具

网游cf活动dnf活动lol周免英雄lol礼包

手游最新动态手游评测手游活动新游预告手游问答

您的位置:首页网页设计DreamWeaver → CSS解决链接锚点定位偏移

CSS解决链接锚点定位偏移

时间:2009/11/6 9:47:00来源:本站整理作者:我要评论(0)

CSS解决链接锚点定位偏移,不知道有没有人研究过这个问题。下下我们帮你讲解下

<!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代码:

/*初始化,使不影响判断*/
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-top:200px solid #000;/*改变目标元素对于锚点的基点位置,这里可以用padding-top,但是有不一样的问题出现,都可以很简单解决,这里不详说了*/
	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; }

相关视频

    没有数据

相关阅读 个性化jQuery和CSS3菜单源码CSS实现Tab技巧CSS复位-CSS Reset代码举例IE6绝对定位的bug及其解决办法CSS样式表创建美妙绝伦的网站几个最常用和实用的CSS技巧将网站(主页)变成黑白DW设计网页时组织CSS的建议

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 CSS优雅的公布栏源码高级CSS选择器的使用 将网站(主页)变成黑白DW设计网页时组织CSS的建议利用Dreamweaver合理优化网页元素布局22个Dreamweaver内置网页过渡特效简介

人气排行 如何用Dreamweaver制作电子相册下拉菜单全攻略-用Dreamweaver制作下拉菜单用Dreamweaver实现ASP数据库动态网站建设用Dreamweaver CS3制作下拉菜单如何在DW中插入Flash的参数详解Dreamweaver标签选择器的妙用巧用dreamweaver模板批量制作网页优化HTML代码加快网页速度