╋艺 镇╋╋网站网络|程序语言|Flash╋┣◇网站建设&Web语言 → CSS规范:你真的了解盒模型吗?(1)


  共有22627人关注过本帖树形打印复制链接

主题:CSS规范:你真的了解盒模型吗?(1)

美女呀,离线,留言给我吧!
admin
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 司令 亲民勋章
等级:管理员 帖子:3027 积分:27521 威望:0 精华:7 注册:2003/12/30 16:34:32
CSS规范:你真的了解盒模型吗?(1)  发帖心情 Post By:2011/1/18 17:19:02 [只看该作者]

    什么是CSS的盒子模式呢?在网页设计中我们常听的属性名是:内容(content)、填充(padding)、边框(border)、边界(margin), CSS盒模式都具备这些属性。

    为了给文档树中的各个元素排版定位(布局),浏览器会根据渲染模型(是讲元素怎么在页面上定位及布局的,包括position和float等等,visual formatting model)为每个元素生成四个嵌套的矩形框,分别称作content box、padding box、border box 和margin box。

    以上说的四种类型是不可分割的,并可能会重合,这就是CSS规范中描述的“盒模型”(box model),也就是以CSS的角度去看一个元素被渲染后的抽象形态。是讲一个元素自身的构成部分,不同于布局:多个元素在页面上的定位。

    51CTO推荐阅读:CSS布局:Web标准必备小结

    <!--EndFragment-->

    图例

    上面的大框,代表一个元素生成的矩形区域,也就是 box,每一个 box 都包括一个 content 区域(元素的内容,如文本,图形等)以及环绕其四周的 padding(元素的内边距,填充部分)、border (元素的边框) 和 margin (元素的外边距) 区域。padding、border 和 margin 区域都包括 top、right、bottom、left 四部分。如图所示(“LM”代表left margin,“RP”代表right padding,“TB”代表top border……)。

    边界

    上述四个区域(content、 padding、border和margin)分别有他们自己的边界,细化来说,每个区域都有top、right、bottom、left四个边界。

    ◆content 边界/内边界

    Content 边界环绕在由该元素的宽和高决定的一个矩形上,这个尺寸通常由该元素渲染后的内容决定。这四个content边界组成的矩形框就是该元素的 content box。

    ◆padding边界

    Padding 边界环绕在该元素的 padding区域的四周,顾名思义,填充背景色,在此范围内有效。如果padding的宽度为0,则padding边界与content边界重合。这四个padding边界组成的矩形框就是该元素的padding box。

    ◆border 边界

    Border 边界环绕在该元素的border区域的四周,如果border的宽度为0,则border边界与padding边界重合。这四个border边界组成的矩形框就是该元素的 border box。

    ◆margin 边界/外边界

    Margin 边界环绕在该元素的margin区域的四周,如果margin的宽度为0,则margin边界与border边界重合。这四个margin边界组成的矩形框就是该元素的 margin box。下面分别说一下各个部分。一个简单的例子,来自 W3C 官方:

    1. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN"> 
    2. <HTML> 
    3. <HEAD> 
    4. <TITLE>Examples of margins, padding, and borders</TITLE> 
    5. <STYLE type="text/css"> 
    6. UL {  
    7. background: yellow;  
    8. margin: 12px 12px 12px 12px;  
    9. padding: 3px 3px 3px 3px;   
    10. /* No borders set */  
    11. }  
    12. LI {  
    13. color: white; /* text color is white */  
    14. background: blue; /* Content, padding will be blue */  
    15. margin: 12px 12px 12px 12px;  
    16. padding: 12px 0px 12px 12px; /* Note 0px padding right */  
    17. list-style: none /* no glyphs before a list item */  
    18. /* No borders set */  
    19. }  
    20. LI.withborder {  
    21. border-style: dashed;  
    22. border-width: medium; /* sets border width on all sides */  
    23. border-color: lime;  
    24. }  
    25. </STYLE> 
    26. </HEAD> 
    27. <BODY> 
    28. <UL> 
    29. <LI>First element of list</LI> 
    30. <LI class="withborder">Second element of list is  
    31. a bit longer to illustrate wrapping.</LI> 
    32. </UL> 
    33. </BODY> 
    34. </HTML> 

    示意图:

    示意图




  
“艺镇”官方站:www.zyzsky.com QQ群:1221854  回到顶部
美女呀,离线,留言给我吧!
admin
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 司令 亲民勋章
等级:管理员 帖子:3027 积分:27521 威望:0 精华:7 注册:2003/12/30 16:34:32
  发帖心情 Post By:2011/1/18 17:19:29 [只看该作者]

margin

'margin' 是 'margin-top', 'margin-right', 'margin-bottom', 'margin-left' 的简写,表明 margin 的大小范围。它的值可以是宽度值、百分比值或‘auto’这3者之一,注意:宽度值必须带有单位。

margin简写

1. 以上、右、下、左的顺序给以上四个值赋值。

  1. CSS codemargin: 1px 2px 3px 4px;
  2.  

等价于:

  1. CSS codemargin-top: 1px  
  2. margin-right: 2px  
  3. margin-bottom: 3px  
  4. margin-left: 4px 
  5.  

记住,从上面开始,顺时针旋转一圈。

2. 以上下、左右的顺序赋值

  1. CSS codemargin: 1px 2px;
  2.  

那么相当于:

  1. CSS codemargin-top: 1px  
  2. margin-right: 2px  
  3. margin-bottom: 1px  
  4. margin-left: 2px
  5.  

这种赋值方式,适合下面讲到的 *-top,*-right,*-bottom,*-left的简写的赋值,如padding,border-width,border-color等,下面不再说明。

可以应用在什么元素上

非table类型的元素,以及table类型中table-caption, table 和inline-table这3类。例如 TD TR TH等,margin是不适用的。

什么时候无效

对于行内非替换元素(例如 SPAN),垂直方向的margin不起作用。例如:

  1. <div style="border:1px solid red;"> 
  2. <span style="margin:100px; background:gray;">ddd</span> 
  3. </div> 
  4.  

可以看到,DIV 的上下 border 紧贴着灰色的SPAN元素。

margin折叠

垂直方向上的不同元素的相邻的margin在某些情况下,会发生折叠的现象。比如,两个 div ,上下相邻,上面 DIV 的margin-bottom 会和 下面 DIV 的 margin-top 产生折叠的现象,两个重叠成一个,具体宽度取较大的。例如:

  1. <div style="background-color:green; width:100px; height:100px;margin-bottom:100px;"> 
  2. </div> 
  3. <div style="background-color:red; width:100px; height:100px; margin-top:50px;"> 
  4. </div> 
  5.  

上下两个DIV最终相距100px,而不是150px。



  
“艺镇”官方站:www.zyzsky.com QQ群:1221854  回到顶部
美女呀,离线,留言给我吧!
admin
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 司令 亲民勋章
等级:管理员 帖子:3027 积分:27521 威望:0 精华:7 注册:2003/12/30 16:34:32
  发帖心情 Post By:2011/1/18 17:19:43 [只看该作者]

padding

padding是 'padding-top', 'padding-right', 'padding-bottom', 'padding-left'的缩写。赋值的方法跟margin相同,只是没有 ‘auto’ 值。默认值是0。

它可以应用到的元素

除display值是 ‘table-row-group’, ‘table-header-group’, ‘table-footer-group’, ‘table-row’, ‘table-column-group’ 和 ’table-column’ 的所有元素。

border

border是个比较复杂的东西。它是'border- top', 'border-right', 'border-bottom', 'border-left'。千万别认为它跟前面的padding还有 margin一样只是设置width就好了。

border包含3个部分,’border-width’,’border- color’,’border-style’,分别用来设置它的宽度,颜色和样式。适用于任何元素。

border-width是 'border-top-width', 'border-right-width', 'border-bottom-width', 'border-left-width'。默认值是0。可用值有‘thin’,‘medium’,‘thick’,以及常用的数值带单位的宽度值。

border-color是'border-top-color', 'border-right-color', 'border-bottom-color', 'border-left-color'的简写。默认值是 ‘color’ 特性的值。

border-style是'border-top-style', 'border-right-style', 'border-bottom-style', 'border-left-style'的简写。默认值是 none 特性的值。可用值有:’none’,’hidden’,’dotted’,’dashed’,’solid’,’double’,’groove’,’ridge’,’inset’,’outset’,有兴趣的可以逐个试试效果。



  
“艺镇”官方站:www.zyzsky.com QQ群:1221854  回到顶部
美女呀,离线,留言给我吧!
admin
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 司令 亲民勋章
等级:管理员 帖子:3027 积分:27521 威望:0 精华:7 注册:2003/12/30 16:34:32
  发帖心情 Post By:2011/1/18 17:19:57 [只看该作者]



  
平面设计、网站建设、三维动画、视频制作 联系QQ:114103945  回到顶部
美女呀,离线,留言给我吧!
admin
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 司令 亲民勋章
等级:管理员 帖子:3027 积分:27521 威望:0 精华:7 注册:2003/12/30 16:34:32
  发帖心情 Post By:2011/1/18 17:20:39 [只看该作者]

为了处理以web标准制作的,和上个世纪90年代末流行的网页,浏览器提供一套方法来分别渲染。[http://zh.wikipedia.org/zh-cn/Internet_Explorer_6 Intelnet Explorer 6]分为两大模式:标准模式,怪癖模式<ref>Internet Explorer从第六版开始,变成有两种执行模式,其中一种称为标准模式(standards mode),另一为称为相容模式(quirks mode),两种模式会自行切换,程序运作时使用哪一种模式,则视网页的HTML或XHTML语法中的DTD定义怎么宣告。

--文字来源:[http://zh.wikipedia.org/zh-cn/Trident_(排版引擎)#_note-1 Trident (排版引擎)]</ref>。

标准模式照顾以web标准方式创作的页面,而怪癖模式则以老版本浏览器的机制来渲染页面,以使陈旧的网页能够较正常的浏览。这两大模式对CSS2.1规范的解析均有很大差异,尤其是对[[盒模型]]<ref>box-model,是以CSS技术做为网页排版时的一个很重要的观念,它描述了元素之间的彼邻关系,同时也左右了设计者是否能够成功透过CSS ,完成整个网页页面的呈现。 --文字来源:[http://zh.wikipedia.org/zh-cn/Trident_(排版引擎)#_note-0 Trident (排版引擎)]</ref>的解释,因此如何确定文档声明至关重要,这直接影响到页面在浏览器中的显示效果。





  
“艺镇”官方站:www.zyzsky.com QQ群:1221854  回到顶部
美女呀,离线,留言给我吧!
admin
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信 司令 亲民勋章
等级:管理员 帖子:3027 积分:27521 威望:0 精华:7 注册:2003/12/30 16:34:32
  发帖心情 Post By:2011/1/18 17:21:36 [只看该作者]

document.compatMode介绍

所以为兼容性考虑,我们可能需要获取当前的文档渲染方式。
      document.compatMode正好派上用场,它有两种可能的返回值:BackCompat和CSS1Compat,对其解释如下:
BackCompat Standards-compliant mode is not switched on. (Quirks Mode)
CSS1Compat Standards-compliant mode is switched on. (Standards Mode)


地址:
http://www.javaeye.com/topic/151528
[此贴子已经被作者于2011-1-18 17:24:39编辑过]


  
“艺镇”官方站:www.zyzsky.com QQ群:1221854  回到顶部