由浅入深漫谈margin属性

作者:blank 来源:蓝色经典 时间:2007-05-11 17:03:00 

blankzheng的blog:http://www.planabc.net/

margin在中文中我们翻译成外边距或者外补白(本文中引用外边距)。他是元素盒模型(box model)的基础属性。

一、margin的基本特性

margin属性包括margin-top,margin-right,margin-bottom,margin-left,margin,可以用来设置box的margin area。属性margin可以用来同时设置box的四边外边距,而其他的margin属性只能设置其自各的外边距。

margin属性可以应用于几乎所有的元素,除了表格显示类型(不包括 table-caption, table and inline-table)的元素,而且垂直外边距对非置换内联元素(non-replaced inline element)不起作用。

或许有朋友对非置换元素(non-replaced element)有点疑惑,稍微帮助大家理解一下。非置换元素,W3C中没有给出明确的定义,但我们从字面可以理解到,非置换元素对应着置换元素(replaced element),也就是说我们搞懂了置换元素的含义,就懂了非置换元素。置换元素,W3C中给出了定义:

引用:

“An element that is outside the scope of the CSS formatter, such as an image, embedded document, or applet”


从定义中我们可以理解到,置换元素(replaced element)主要是指img,input,textarea,select,object等这类默认就有CSS格式化外表范围的元素。进而可知,非置换元素(non-replaced element)就是除了img,input,textarea,select,object等置换元素以外的元素。

margin始终是透明的。

二、margin的基本写法

外边距的margin-width的值类型有:auto | length | percentage

percentage:百分比是由被应用box的containing block(注:一个元素的containing block是该元素产生的box(es)在计算位置和大小时参考的一个矩形,详细阅读可看:《Containing Block》)的大小所决定。对于margin-top和margin-bottom也同样成立。

margin的默认值为0,并且margin支持负值。

上面我们曾提到属性margin可以用来同时指定box的四边外边距。如果属性margin有四个值,那么值将按照上-右-下-左的顺序作用于四边,即从元素的上边开始,按照顺时针的顺序围绕元素。表达式如下:


margin:top right bottom left;


四个数值中间以空格分隔。效果等同于:


margin-top:value;
margin-right:value;
margin-bottom:value;
margin-left:value;


并且规范还提供了省略的数值写法,基本原则如下:

引用:

1.如果没有left值,则使用right代替;
2.如果没有bottom值,则使用top代替;
3.如果没有right值,则使用top值代替。


根据这些基本原则,我们可以有三种省略方式,但不管怎样省略margin的数值都会大于等于一个,而margin的默认数值是从top开始至left结束,那么对于省略的具体情况,我们可以从left反推理回去。

1.如果margin只有三个值,按照值的顺序为margin:top right bottom; 缺少了left,根据原则,则left的值有right来代替。

margin:10px 20px 30px;就等于margin:10px 20px 30px 20px;

2.如果margin只有两个值,按照值的顺序为margin:top right; 缺少了bottom和left,根据原则left的值由right来代替,bottm的值由top来代替。

margin:10px 20px;就等于margin:10px 20px 10px 20px;

3.如果margin只有一个值,按照值的顺序为margin:top; 缺少了bottom、left和right,根据原则left的值由right来代替,bottom的值由top来代替,right的值右top来代替,也就是说left的值也由top来代替。

margin:10px;就等于margin:10px 10px 10px 10px;

标签:margin,用法,属性
0
投稿

猜你喜欢

  • Div+CSS网页布局对SEO的影响漫谈

    2008-08-22 12:58:00
  • oracle下实现恢复一个丢失的数据文件的代码

    2009-03-02 11:02:00
  • 移动网站开发:标记语言

    2010-06-08 13:42:00
  • Google中国新首页风格再度变脸

    2008-10-27 13:37:00
  • 整理一个asp多级树型分类问题的解决方法

    2007-10-17 18:38:00
  • 微软建议的ASP性能优化28条守则(4)

    2008-02-26 17:57:00
  • asp Driver和Provider两种连接字符串连接Access时的区别

    2011-03-09 11:19:00
  • 最小asp后门程序

    2011-04-03 10:35:00
  • 形象化的reflow

    2008-06-08 13:33:00
  • DHTML实例解析:用HTC统一定制表单样式

    2007-11-04 18:48:00
  • MySQL重定位数据库目录的内容

    2009-02-26 16:03:00
  • 多语言网站开发 不完全技术分析

    2008-02-18 12:52:00
  • JQuery获取表单值

    2009-11-19 13:17:00
  • 如何制作关联的下拉菜单?

    2010-06-29 21:19:00
  • CSS 表格元素内容的定位 0

    2008-08-01 17:31:00
  • javascript 密码强度验证规则、打分、验证

    2010-05-18 19:58:00
  • Bresenham图形算法JavaScript版本

    2010-01-25 12:09:00
  • WEB页面工具语言XML应用分类之运用

    2008-05-29 10:58:00
  • 关于reflow

    2007-09-23 13:30:00
  • 类型为search的input及相关属性

    2009-02-11 12:49:00
  • asp之家 网络编程 m.aspxhome.com