HTML嵌套规则

  先说基础,HTML标签有两类:

  1、块级元素

  div、h1~h6、address、blockquote、center、dir、dl、dt、dd、fieldset、form、hr、isindex、menu、noframes、noscript、ol、p、pre、table、ul……

  特点:总是在新行上开始,高度、行高以及顶和底边距都可控制,宽度缺省的它的容器的100%,除非设定一个宽度。

  功能:主要用来搭建网站构架、页面布局、承载内容。

  2、行内元素

  span、a、abbr、acronym、b、bdo、big、br、cite、code、dfn、em、font、i、img、input、kbd、label、q、s、samp、select、small、strike、strong、sub、sup、textarea、tt、u、var……

  特点:和其他元素都在一行上,高、行高及顶和底边距不可改变,宽度就是它的文字或图片的宽度,不可改变。

  功能:用于加强内容显示,控制细节,例如:加粗、斜体等。

  虽然HTML标签有很多,并且我们在制作页面的时候可以无限的嵌套,但是嵌套也有规则,不能随意的嵌套。

  有些标签是固定的嵌套规则,例如:ul包含li、ol包含li、dl包含dt和dd等,还有很多是独立的标签。为了写出更优秀的页面,一般遵循下面的规则:

  1、块级元素与块级元素平级、内联元素与内联元素平级;

<div><span></span><p></p></div>  //span是内行元素,p是块级元素,所以这个是错误的嵌套

<div><span></span><a></a></div>  //这个是正确的嵌套

  2、块级元素可以包含内联元素或某些块级元素,但内联元素不能包含块级元素,它只能包含其他的内联元素;

<div><span></span></div>
<span><span></span></span>

  3、有几个特殊的块级元素只能包含内联元素,不能再包含块级元素;

h1、h2、h3、h4、h5、h6、p、dt

  4、块级元素不能放在标签p里面;

  5、li标签可以包含div标签,因为li和div标签都是装在内容的容器。

  小结:为了提高浏览器的渲染效率,我们应该尽少的嵌套标签,扁平化。

  关于HTML5新特性

  在HTML5 中,元素不再按照display属性来区分,而是按照内容模型来区分,分为:

  元数据型(metadata content)是可以被用于说明其他内容的表现或行为,或者在当前文档和其他文档之间建立联系的元素;

  区块型(sectioning content)是用于定义标题及页脚范围的元素;

  标题型(heading content)定义一个区块/章节的标题;

  文档流型(flow content)是在应用程序和文档的主体部分中使用的大部分元素;

  语句型(phrasing content)是用于标记段落级文本的元素;

  内嵌型(embedded content)是引用或插入到文档中其他资源的元素;

  交互型(interactive content)是专门用于与用户交互的元素。

  元素不属于任何一个类别,被称为穿透的;元素可能属于不止一个类别,称为混合的。

  下面对常用标签的嵌套规则进行总结

  1、<h1>、<h2>、<h3>、<h4>、<h5>、<h6>、<p>的子元素是语句型元素

  2、<header>、<footer>不可嵌套<header>、<footer>

  3、<a>的子元素是transparent(以它的父元素允许的子元素为准),但不包括交互型元素(interactive content)

  4、<form>不可嵌套<form>

  5、<button>子元素是语句型元素,不可嵌套交互型元素(interactive content)

  6、<caption>不可嵌套<table>

  7、<dt>、<th>不可嵌套<header>、<footer>、区块型元素(sectioning content)、标题型元素(heading content)

  

  PS:以上内容整理自网络,如有错误或遗漏欢迎大家指正。

时间: 2024-12-17 18:49:06

HTML嵌套规则的相关文章

HTML标签的嵌套规则

我在平时在写html文档的时候,发现不太清楚标签之间的嵌套规则,经常是想到什么标签就用那些,后来发现有些标签嵌套却是错误的.通过网上找资料,了解了html标签的嵌套规则. 一.HTML 标签包括 块级元素(block).内联元素(inline)  1.块级元素  一般用来搭建网站架构.布局.承载内容的元素,如下:  address.blockquote.center.dir.div.dl.dt.dd.fieldset.form.h1~h6.hr.isindex.menu.noframes.nos

HTML的奇葩嵌套规则

一.HTML 标签包括 块级元素(block).内嵌元素(inline) 1.块级元素 一般用来搭建网站架构.布局.承载内容……它包括以下这些标签: address.blockquote.center.dir.div.dl.dt.dd.fieldset.form.h1~h6.hr.isindex.menu.noframes.noscript.ol.p.pre.table.ul 2.内嵌元素 一般用在网站内容之中的某些细节或部位,用以“强调.区分样式.上标.下标.锚点”等等,下面这些标签都属于内嵌

块状元素与内联(行内)元素的嵌套规则

如果不按照HTML规则书写代码时,浏览器就不会正确解析,会将不符合嵌套规则的节点放到目标节点的下面,或者变成纯文本.HTML存在许多种类型的标签,有的标签下面只允许特定的标签存在,这就是HTML嵌套规则.        块状元素:一般是其他元素的容器,可容纳内联元素和其他块状元素,块状元素排斥其他元素与其位于同一行,宽度(width)高度(height)起作用. 内联元素(行内元素):内联元素只能容纳文本或者其他内联元素,它允许其他内联元素与其位于同一行,但宽度(width)高度(height)

项目期复习总结2:Table, DIV+CSS,标签嵌套规则

文件夹: 1.表格的意义,含义? 2.表格有哪些元素? 3.表格布局,表格布局的优缺点 4.行元素,块元素的差别? 5.标签的合理嵌套及标签的语义性 ① 表格的意义,含义? 表格应该用来展现那些适合表格化显示的信息,比方数据的显示,统计或者二维报表之类的信息,而不是作为一种而已的工作 ② 表格有哪些元素? 表格元素:table thead tbody tfoot caption tr th td .... 较经常使用  ③ 表格的使用应该注意哪些? 1)使用表格时注意合理嵌套,遵循标签的语义性,

Less学习笔记 -- Nested rules (嵌套规则)

Less嵌套规则模仿了HTML结构,这样写可以让代码更简洁.更具层次感,上一小段代码先了解下 Less代码: #header{   color:black;   .navigation{     font-size:12px;   }   .logo{     width:300px;   } } CSS编译代码: #header {   color: black; } #header .navigation {   font-size: 12px; } #header .logo {   wi

XHTML嵌套规则

XHTML的标签有许多:div.ul.li.dl.dt.dd.h1~h6.p.a.addressa.span. strong--我们在运用这些标签搭建页面结构的时候,是可以将它们无限嵌套的,但是,嵌套也需要有一定规则,不能任由自己的个人习惯胡乱嵌套-- XHTML 必竟不是 XML.在 XHTML 的语言里,我们都知道:ul 标签包含着 li.dl 标签包含着 dt 和 dd--这些固定标签的嵌套规则十分明确.但是,还有许多标签是独立的,它们没有被捆绑在一起,比如 h1.div.p--那么这些标

Html 标签的嵌套规则

一.HTML 标签包括 块级元素(block).内嵌元素(inline) 1.块级元素 一般用来搭建网站架构.布局.承载内容--它包括以下这些标签: address.blockquote.center.dir.div.dl.dt.dd.fieldset.form.h1~h6.hr.isindex.menu.noframes.noscript.ol.p.pre.table.ul       2.内嵌元素 一般用在网站内容之中的某些细节或部位,用以"强调.区分样式.上标.下标.锚点"等等,

HTML标签嵌套规则

摘要:  最近在整理项目时发现有些同事写的页面代码嵌套的太多,而且有些嵌套不对,比如<a><div>内容</div></a>.虽然功能实现了,但是对于浏览器渲染引擎的性能还是有些影响.所以就大体上的整理了下HTML标签的嵌套规则,也希望读者提出不对之处. 众所周知,HTML标签有两类: 块级元素div.h1~h6.address.blockquote.center.dir.dl.dt.dd.fieldset.form.hr.isindex.menu.nofr

HTML的元素嵌套规则

一.HTML 标签包括 块级元素(block).内嵌元素(inline) 1.块级元素 一般用来搭建网站架构.布局.承载内容……它包括以下这些标签: address.blockquote.center.dir.div.dl.dt.dd.fieldset.form.h1~h6.hr.isindex.menu.noframes.noscript.ol.p.pre.table.ul 2.内嵌元素 一般用在网站内容之中的某些细节或部位,用以“强调.区分样式.上标.下标.锚点”等等,下面这些标签都属于内嵌