您的位置: 首页 > 技术文档 > 网页制作 > 由浅入深漫谈margin属性
PDF、ZIP、DOC链接的标注 回到列表 彻底弄懂CSS盒子模式之一
 由浅入深漫谈margin属性

作者:blank 时间: 2007-03-19 文档类型:原创 来自:蓝色理想

第 1 页 由浅入深漫谈margin属性 [1]
第 2 页 由浅入深漫谈margin属性 [2]

三、margin的解析逻辑

目前我们已经了解到了margin的基本特性和基本写法,但对元素margin的基本解析逻辑还是很模糊,到底margin的top、right、bottom、left都是以什么为基准来促使box model形成。为了形象,易懂的对margin的逻辑进行说明,下面讲解的过程中,将引入W3C上没有的参考线的说法。何谓参考线?参考线就是margin移动的基准点,此基准点相对于box是静止的。而margin的数值,就是box相对于参考线的位移量。

在margin中top、right、bottom、left的参考线并不一致为一类,而是分为了两类参考线,top和left的参考线属于一类,right和bottom的参考线属于另一类。那他们到底各以什么为参考线呢?top以containing block的content上边或者垂直上方相连元素margin的下边为参考线垂直向下位移;left以containing block的content左边或者水平左方相连元素margin的右边为参考线水平向右位移。right以元素本身的border右边为参考线水平向右位移;bottom以元素本身的border下边为参考线垂直向下位移。从上我们可以看到top和left都是以外元素为参考,而right和bottom以本元素为参考。上面的位移方向是指margin数值为正值时候的情形,如果是负值则位移方向相反。

或许理论听起来比较枯燥,我们举例说明一下:

<!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 type="text/css">
div {width:200px; height:200px; background:#ccc;}
</style>
</head>

<body>
  <div>外边距的margin-width的值类型有:auto | length | percentage</div>
</body>
</html>

如上代码,很简单,为了方便我们看到效果,我们给div设置了宽度和高度以及背景色。

现在我们给div的样式加上margin属性,比如:

margin:-10px 20px -30px 40px;

这时候margin的解析逻辑是怎样的呢?首先我们要搞清div的和周边元素的关系,div没有相连元素,而此时div的containing block是body产生的block box。则根据上面介绍的参考线原理,div的左外边距以containing block的content左边为参考线,及此时以body的content左边为参考线进行水平向右位移,位移的大小为40px,同理,上边距以body的content上边为参考线进行垂直向上位移10px(负值和正值的方向相反),下边距依照现在div的borer下边(此时的div已经经过上边距位移过了)垂直向上位移30px(此时,margin不会改变box的border内的物理大小,但会改变box的逻辑大小,即:以此box的margin的下边为参考的元素,不是从box的物理位置开始的,而是从逻辑位置开始),右边距依照现在div的borer右边(此时的div已经经过左边距位移过了)水平向右位移20px。或许有朋友问你分析的顺序怎么和margin表达式中出现的顺序不一样?如果按照margin表达式中出现的顺序来分析,结果是一样的,只是为了更好的方便大家的理解而没有按照表达式的顺序来分析。

用margin最后的实际显示大小的到底是怎么样呢,或许有朋友也比较疑惑,我暂时用逻辑大小和物理大小来区分(其实上面已用到此概念),到底什么是逻辑大小,什么是物理大小呢?!具体可以看图,物理大小指的是除去margin,也就是包含border以内的box大小,而逻辑大小,则是box通过margin解析规则解析后得到的大小(这或许可以解释为什么IE5会错误解析盒模型)。在上图中,box的实际显示的宽度等于box的逻辑大小,而box实际显示的高度等于box的物理大小,这说明box实际显示的大小可能是box的逻辑大小,也可能是box的物理大小,规则到底是怎样的——

box的实际大小=box的物理大小+正的margin

这仅对元素本身有效,对于其后面的相关元素,他们则只以margin的逻辑大小为准则,进行布局。

有朋友反应,听得很迷糊,越看越不懂,如果你对具体的理解过程不感兴趣的话,那记住下面我总结的结论就可以了,XD

结论box最后的显示大小等于box的border及border内的大小加上正的margin值。而负的margin值不会影响box的实际大小,如果是负的top或left值会引起box的向上或向左位置移动,如果是bottom或right只会影响下面box的显示的参考线。

经典论坛讨论:
http://bbs.blueidea.com/thread-2728471-1-1.html

本文链接:http://www.blueidea.com/tech/web/2007/4546.asp 

出处:蓝色理想
责任编辑:moby

上一页 由浅入深漫谈margin属性 [1] 下一页

◎进入论坛网页制作网站综合版块参加讨论

相关文章 更多相关链接
设计五原则
Web 表单设计原则和实践
像table一样布局div II
学习CSS布局心得
关于中英文正文字体比较
作者文章 更多作者文章
42个值得阅读的设计/技术杂志
网站浏览器兼容的底线
display:inline-block的深入理解
CSS实例讲解:地图提示
中英文双语导航菜单
热门搜索:CSS Fireworks 设计比赛 网页制作 web标准 用户体验 UE photoshop Dreamweaver Studio8 Flash 手绘 CG
站点最新 站点最新列表
全兼容的纯CSS级联菜单要点浅析
CSS Sprites 图片整合技术
雅安,一场中式旅行
热烈祝贺"醒狮杯"圆满结束
菊花宝典大赏大奖教程《阳台》
交互设计师怎样和产品团队合作
Photoshop打造个性潮流音乐海报
简单解读面包屑
CSS盒模型
Apple与Microsoft网站可用性研究
栏目最新 栏目最新列表
safari 4 新特性
Photoshop制作精美高光流线字
IE下img多余5像素空白解决方法
XHTML1.0与HTML兼容指引16条
JavaScript优化细节
全兼容的纯CSS级联菜单要点浅析
CSS Sprites 图片整合技术
Photoshop打造个性潮流音乐海报
CSS盒模型
45度地图编辑器及游戏开发心得
>> 分页 首页 前页 后页 尾页 页次:2/21个记录/页 转到 页 共2个记录

蓝色理想版权申明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有。

转载要求:转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。

特别注意:本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有,文章若有侵犯作者版权,请与我们联系,我们将立即删除修改。

本文总共有 12 条评论,现在显示最新的 5 条。评分:- llllllllllllllllllll + 评分人数: 3 ,平均分: 2.00


huogr Publish at 2009-6-11 9:36:23 评分4
自己亲自动作做一边,便豁然开朗.
xiejianfan035 Publish at 2009-5-1 19:12:11
呵呵,说得倒是细致。 不懂的想要弄懂的话, 去尝试吧。 尝试不同数值的效果, 会明白的。
feng0223 Publish at 2008-12-25 15:26:55
那他们到底各以什么为参考线呢?top以containing block的content上边或者垂直上方相连元素margin的下边为参考线垂直向下位移
====================
我的理解应该是:
top是以 border 的上边或者垂直上方相连元素margin的下边为参考线
zhuhaisto Publish at 2008-10-28 21:43:17
太复杂了,我没办法理解,新手啊
blankzheng Publish at 2007-3-31 9:38:26
文章最后的文字和图进行了某些调整。或许是把简单的说得复杂了,只是想大家能了解他们的逻辑机制,呵呵,就像1+1=2,大家都知道,但为什么等于2呢,或许论证的过程是枯燥的公式罢了。

查看全部评论

您的评论
用户名:  口令:
说明:输入正确的用户名和密码才能参与评论。如果您不是本站会员,你可以注册 为本站会员。
注意:文章中的链接、内容等需要修改的错误,请用报告错误,以利文档及时修改。
不评分 1 2 3 4 5
注意:请不要在评论中含与内容无关的广告链接,违者封ID
请您注意:
·不良评论请用报告管理员,以利管理员及时删除。
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·承担一切因您的行为而直接或间接导致的民事或刑事法律责任
·本站评论管理人员有权保留或删除其管辖评论中的任意内容
·您在本站发表的作品,本站有权在网站内转载或引用
·参与本评论即表明您已经阅读并接受上述条款
推荐文档 | 打印文档 | 评论文档 | 报告错误  
专业书推荐 更多内容
《Web标准设计》
《美工神话》
《Flash短片轻松学》
Illustrator CS3质感绘画表现技法
大师之路--Photoshop 完全解析
《用户体验要素》
HTML与CSS入门经典(第7版)
作品集 更多内容

用CSS写的Michael Ja 毕业设计。 02年临摹的小图 变态金刚 胡椒下班 家居城 artery_free_10 Juvenile Adult