下面小编就为大家带来一篇html5标签嵌套规则详解【必看】。小编觉得挺不错的,现在分享给大家,也给大家做个参考
前面的话
在html5中,元素的子元素可以是块级元素,这在以前是被认为不符合规则的。本文将详细介绍html5的标签嵌套规则
分类
html5出现之前,经常把元素按照block、inline、inline-block来区分。在html5中,元素不再按照display属性来区分,而是按照内容模型来区分。
分为元数据型(metadata content)、区块型(sectioning content)、标题型(heading content)、文档流型(flow content)、语句型(phrasing content)、内嵌型(embedded content)、交互型(interactive content)。元素不属于任何一个类别,被称为穿透的;元素可能属于不止一个类别,称为混合的。
元数据元素(metadata content)是可以被用于说明其他内容的表现或行为,或者在当前文档和其他文档之间建立联系的元素
立即学习“前端免费学习笔记(深入)”;
base link meta noscript script style template title
流元素(flow content)是在应用程序和文档的主体部分中使用的大部分元素
a abbr address area(如果它是map元素的子元素) article aside audio b bdi bdo blockquote br button canvas cite code data datalist del dfn div dl em embed fieldset figure footer form h1 h2 h3 h4 h5 h6 header hr i iframe img input ins kbd keygen label main map mark math meter nav noscript object ol output p pre progress q ruby s samp script section select small span strong sub sup svg table template textarea time u ul var video wbr text
区块型元素(sectioning content)是用于定义标题及页脚范围的元素
article aside nav section
标题型元素(heading content)定义一个区块/章节的标题
h1 h2 h3 h4 h5 h6
语句型元素(phrasing content)是用于标记段落级文本的元素
a abbr area (如果它是map元素的子级) audio b bdi bdo br button canvas cite code data datalist del dfn em embed i iframe img input ins kbd keygen label map mark math meter noscript object output progress q ruby s samp script select small span strong sub sup svg template textarea time u var video wbr text
嵌入型元素(embedded content)是引用或插入到文档中其他资源的元素
audio canvas embed iframe img math object svg video
交互型元素(interactive content)是专门用于与用户交互的元素
a audio(如果设置了controls属性) button embed iframe img(如果设置了usemap属性) input(如果type属性不为hidden) keygen label object(如果设置了usemap属性) select textarea video (如果设置了controls属性)
子元素
【1】子元素是流元素
、、、
、、、、、
【1.1】子元素是流元素,不包括元素、 【1.2】子元素是流元素,但不包括 元素 【1.3】子元素是流元素,但不包括元素 【1.4】子元素是流元素,但不包括、、元素、、 【1.5】子元素是流元素,但不包括、、区块型元素(sectioning content)、标题型元素(heading content) 、 【1.6】子元素是流元素,但不包括、、、区块型元素(sectioning content)、标题型元素(heading content) 【1.7】子元素是一个元素,紧跟着流元素 【1.8】子元素是一个元素,紧跟着流元素
【2】子元素是语句型元素 、、、、、、、 、<em>、<strong>、<small>、<s>、<cite>、<q>、<abbr>、<data>、<time>、<code>、<var>、<samp>、<kbd>、<sub>、<sup>、<i>、<b>、<u>、<mark>、<bdi>、<bdo>、<span>、<input>、<output>、<legend>、<label><br>【2.1】子元素是语句型元素,但不包括和自身相同的元素<p><dfn>、<progress>、<meter><br>【2.2】子元素是语句型元素,但不包括交互型元素(interactive content)</meter></progress></dfn></p><p><button><br> </button></p><p>【3】子元素是transparent(以它的父元素允许的子元素为准)</p><p><ins>、<del>、<map><br>【3.1】子元素是transparent(以它的父元素允许的子元素为准),但不包括交互型元素(interactive content)</map></del></ins></p><p><a><br>【3.2】子元素可以没有、可以是<param>元素,也可以是transparent(以它的父元素允许的子元素为准)</a></p><p><object><br> </object></p><p>【4】无子元素</p><p></p><hr>、<br>、<wbr>、<img alt="解析HTML5中的标签嵌套规则" >、<embed>、<param>、<source>、<track>、<area>、<col>、<keygen><br>【4.1】子元素可以没有、可以是<li>元素,也可以是<script>、<template>元素<p><ol>、<ul><br/>【4.2】子元素可以没有、可以是<dt>和<dd>元素,也可以是<script>、<template>元素<p><dl><br/>【4.3】子元素可以没有,可以是<option>、<optgroup>,也可以是<script>、<template>元素<p><select><br/>【4.4】子元素可以没有,可以是<option>,也可以是<script>、<template>元素<p><optgroup><br/>【4.5】子元素可以没有、可以是<option>元素<p><datalist><br/>【4.6】子元素可以没有、也可以是<track>元素,也可以是<source>元素<p><audio>、<video><br/>【4.7】子元素可以没有,也可以是<col>、<template>元素<p><colgroup><br/>【4.8】子元素可以没有,可以是<tr>,也可以是<script>、<template>元素<p><tbody>、<thead>、<tfoot><br/>【4.9】子元素可以没有,可以是<tr>、<th>,也可以是<script>、<template>元素<p><tr><br/> <p>【5】子元素是<caption>、<colgroup>、<thead>、<tfoot>、<tbody>,也可以是<script>、<template>元素<p><table><br/> <p>【6】子元素是文本内容<p><textarea><br/>【6.1】子元素可以没有,也可以是文本内容<p><option><br/><p><strong><span style="max-width:90%">总结<br/></script></li></keygen></track></source></embed></wbr></label></legend></output></span></bdo></bdi></mark></u></b></i></sup></sub></kbd></samp></var></code></time></data></abbr></q></cite></s></small></strong>关于每个元素的详细嵌套规则,上部分已经详细介绍。这部分主要对常用标签的嵌套规则进行总结<p>[注意]将鼠标移动到深灰色背景的文字上,title将显示该元素所包含的标签</p><p>【1】</p><h1>、<h2>、<h3>、<h4>、<h5>、<h6>、</h6></h5></h4></h3></h2></h1><p>的子元素是语句型元素</p><p>【2】<header>、<footer>不可嵌套<header>、<footer></footer></header></footer></header></p><p>【3】<a>的子元素是transparent(以它的父元素允许的子元素为准),但不包括交互型元素(interactive content)</a></p><p>【4】</p><form>不可嵌套</form><form><p>【5】<button>子元素是语句型元素,不可嵌套交互型元素(interactive content)</button></p><p>【6】</p><caption>不可嵌套<table><p>【7】</p><dt>、<th>不可嵌套<header>、<footer>、区块型元素(sectioning content)、标题型元素(heading content)<p>【 | |