css盒子模型盒子之间的关系

1.标准流: 指的就是在不使用其他的与排列和定位相关的特殊css规则时,块级和行内元素的排列规则。
<body>
    <ul>
      <li>
1个列表的第1个项目内容</li>     
      <li>
1个列表的第2<span>项目内容</span>,内容更长一些,目的是演示自动折行的效果。</li>
    </ul>
    <ul>
      <li><a href=’#’>
2个列表</a>的第1个项目内容</li>
      <li>
2个列表的第2个项目内容,内容更长一些,目的是演示自动折行的效果。</li>
    </ul>  </body>
   
代码中,body本身就是一个最大的块级元素,body中有两个列表(ul),每个列表中又各有两上列表项目(li)。一共有四层,顶层为body,第二层为ul,第三层为li,第四层为文本。

   ulli都为块级元素,而<span>则为行内元素,从DOM的角度来看,块级元素和行内元素是没有区别的,都是树上的一个节点,而从css的角度来看,二者就有很多的区别,块级元素有属于自己的区域,而行内元素没有!标准流就是css规定的默认的块级无素和行内元素的排列方式。

   body标记开始,依次把其中的子元素放到适当的位置。如果一个html更为复杂,层次更多,那么也这个一样,直至所有的元素被检查一遍,分配到相应的区域。在这个过程,一个一个盒子自然地形成一个序列,同级别的盒子依次排列在父级盒子中,就像一条河流有干流和支流一样,这就是被称为的原因。

 

  CSS文档流与块级元素(block)、行内元素(inline.

  将窗体自上而下分成一行行, 并在每行中按从左至右的顺序排放元素,即为文档流.

  每个非浮动块级元素都独占一行, 浮动元素则按规定浮在行的一端. 若当前行容不下, 则另起新行浮动.

  内联元素不会独占一行. 几乎所有元素(包括块级,内联和列表元素)均可生成子行, 用于摆放子元素.

  有三种情况将使得元素脱离文档流而存在,分别是浮动(float),绝对定位(relative), 固定定位(fixed). 但是在IE中浮动元素也存在于文档流中(还让我觉得这样很合理&gt;<).

  浮动元素不占任何正常文档流空间,而浮动元素的定位还是基于正常的文档流,然后从文档流中抽出并尽可能远的移动至左侧或者右侧。文字内容会围绕在浮动元素周围。当一个元素从正常文档流中抽出后,仍然在文档流中的其他元素将忽略该元素并填补他原先的空间。

  浮动概念让人迷惑根源在于浏览器对理论的解读造成的。只能说很多人以IE做标准,其实它不是。

  基于文档流, 我们可以很容易理解以下的定位模式:

·    相对定位,
即相对于元素在文档流中位置进行偏移. 但保留原占位.

·    绝对定位,
即完全脱离文档流, 相对于position属性非static值的最近父级元素进行偏移

·    固定定位,
即完全脱离文档流, 相对于视区进行偏移.

   

CSS权威指南》中文字显示:任何不是块级元素的可见元素都是内联元素。其表现的特性是行布局形式,行布局的意思就是表现形式始终以行进行显示。比如设定一个内联元素border-bottom:1px solid #000;时其表现是以每行进行重复,每一行下方都会有一条黑色的细线。如果是块级元素那么所显示的的黑线只会在块的下方出现。

  ph1、或div等元素常常称为块级元素,这些元素显示为一块内容;Strong,span等元素称为行内元素,它们的内容显示在行中,即行内框。(可用display=block将行内元素转换成块元素,display=none表示生成的元素根本没有框,也既不显示元素,不占用文档中的空间)

A:行内就是在一行内的元素,只能放在行内;块级元素,就是一个四方块,可以放在页面上任何地方。说白了,行内元素就好像一个单词;块级元素就好像一个段落,如果不另加定义的话,它将独立一行出现。

C:一般的块级元素诸如段落&lt;p>、标题<h1><h2>...、列表,<ul><ol><li> 、表格<table>、表单<form>DIV<div>BODY<body>等元素。而内联元素则如: 表单元素<input>、超级链接<a>、图像<img><span> ........

D:块级无素的显著特点是:每个块级元素都是从一个新行开始显示且其后的无素也需另起一行进行显示。

E<span>CSS定义中属于一个行内元素,而<div>是块级元素。

   用容器这一词会更容易形象理解它们的存在与用途,行内元素相当一个小容器,而<div>相当于一个大容器,大容器当然可以放一个小容器了。<span>就是小容器,这样也许会在脑海中有一个初步的印象,如果我们想在大容器中装一些清水。但我也想在里装一些墨水怎么办?很简单,我们把小容器拿出来装上墨水然后放入大容器里的清水中不就成了吗。

 

举个简单的一个实际例子吧:比如

<div>上海网站制作-www.86215.com</div>

我想用CSS定义字母c的样式,因此就可以用到<span>了。

<div>上海网站设计- <span>http://www.86215.com</span> W3C标准</div>

 

块元素(block element)一般是其他元素的容器元素

  块元素一般都从新行开始,它可以容纳内联元素和其他块元素,常见块元素是段落标签'P"“form"这个块元素比较特殊,只能用来容纳其他块元素。

  如果没有css的作用,块元素会顺序以每次另起一行的方式一直往下排。而有了css以后,可以改变这种html的默认布局模式,把块元素摆放到你想要的位置上去。需要指出的是,table标签也是块元素的一种

  内联元素一般都是基于语义级(semantic)的基本元素,只能容纳文本或者其他内联元素,常见内联元素 “a”

  块元素和内联元素的基本差异是块元素一般都从新行开始。而当加入了css控制以后,块元素和内联元素的这种属 性差异就不成为差异了。

  可变元素的基本概念就是他需要根据上下文关系确定该元素是块元素或者内联元素。可变元素还是属于上述两种元素类别,一旦上下文关系确定了他的类别,他就要遵循块元素或者内联元素的规则限制。大致的元素分类见全文。

关于inline element的中文叫法,有多种内联元素、内嵌元素、行内元素、直进式元素。基本上没有统一的翻译,爱怎么叫怎么叫吧。另外提到内联元素,我们会想到有个display的属性是display:inline;这个属性能够修复著名的IE双倍浮动边界问题。

块元素(block element)

  * address - 地址
  * blockquote - 块引用
  * center - 举中对齐块
  * dir - 目录列表
  * div - 常用块级容易,也是css layout的主要标签
  * dl - 定义列表
  * fieldset - form控制组
  * form - 交互表单
  * h1 - 大标题
  * h2 - 副标题
  * h3 - 3级标题
  * h4 - 4级标题
  * h5 - 5级标题
  * h6 - 6级标题
  * hr - 水平分隔线
  * isindex - input prompt
  * menu - 菜单列表
  * noframes - frames可选内容,(对于不支持frame的浏览器显示此区块内容
  * noscript - 可选脚本内容(对于不支持script的浏览器显示此内容)
  * ol - 排序表单
  * p - 段落
  * pre - 格式化文本
  * table - 表格
  * ul - 非排序列表

行内元素(inline element)

  * a - 锚点
  * abbr - 缩写
  * acronym - 首字
  * b - 粗体(不推荐)
  * bdo - bidi override
  * big - 大字体
  * br - 换行
  * cite - 引用
  * code - 计算机代码(在引用源码的时候需要)
  * dfn - 定义字段
  * em - 强调
  * font - 字体设定(不推荐)
  * i - 斜体
  * img - 图片
  * input - 输入框
  * kbd - 定义键盘文本
  * label - 表格标签
  * q - 短引用
  * s - 中划线(不推荐)
  * samp - 定义范例计算机代码
  * select - 项目选择
  * small - 小字体文本
  * span - 常用内联容器,定义文本内区块
  * strike - 中划线
  * strong - 粗体强调
  * sub - 下标
  * sup - 上标
  * textarea - 多行文本输入框
  * tt - 电传文本
  * u - 下划线
  * var - 定义变量

可变元素

  可变元素为根据上下文语境决定该元素为块元素或者内联元素。
  * applet - java applet
  * button - 按钮
  * del - 删除文本
  * iframe - inline frame
  * ins - 插入的文本
  * map - 图片区块(map)
  * object - object对象
  * script - 客户端脚本

 

原文地址:https://www.cnblogs.com/zfang/p/zfang.html