扣丁学堂HTML5视频教程之HTML5标签嵌套规则详解
2017-12-08 14:25:52
602浏览
在html5中,<a>元素的子元素可以是块级元素,这在以前是被认为不符合规则的。本文将详细介绍html5的标签嵌套规则都有哪些呢?下面一起来看一下吧。
html5出现之前,经常把元素按照block、inline、inline-block来区分。在html5中,元素不再按照display属性来区分,而是按照内容模型来区分,分为元数据型(metadatacontent)、区块型(sectioningcontent)、标题型(headingcontent)、文档流型(flowcontent)、语句型(phrasingcontent)、内嵌型(embeddedcontent)、交互型(interactivecontent)。元素不属于任何一个类别,被称为穿透的;元素可能属于不止一个类别,称为混合的。
元数据元素(metadatacontent)是可以被用于说明其他内容的表现或行为,或者在当前文档和其他文档之间建立联系的元素
baselinkmetanoscriptscriptstyletemplatetitle
流元素(flowcontent)是在应用程序和文档的主体部分中使用的大部分元素
区块型元素(sectioningcontent)是用于定义标题及页脚范围的元素
articleasidenavsection
标题型元素(headingcontent)定义一个区块/章节的标题
h1h2h3h4h5h6
语句型元素(phrasingcontent)是用于标记段落级文本的元素
嵌入型元素(embeddedcontent)是引用或插入到文档中其他资源的元素
audiocanvasembediframeimgmathobjectsvgvideo
交互型元素(interactivecontent)是专门用于与用户交互的元素
aaudio(如果设置了controls属性)buttonembediframeimg(如果设置了usemap属性)input(如果type属性不为hidden)keygenlabelobject(如果设置了usemap属性)selecttextareavideo(如果设置了controls属性)
【1】子元素是流元素
<article>、<section>、<blockquote>、<li>、<dd>、<figcaption>、<div>、<main>、<td>
【1.1】子元素是流元素,不包括<main>元素
<aside>、<nav>
【1.2】子元素是流元素,但不包括<table>元素
<caption>
【1.3】子元素是流元素,但不包括<form>元素
<form>
【1.4】子元素是流元素,但不包括<header>、<footer>、<main>元素
<header>、<footer>、<main>
【1.5】子元素是流元素,但不包括<header>、<footer>、区块型元素(sectioningcontent)、标题型元素(headingcontent)
<dt>、<th>
【1.6】子元素是流元素,但不包括<header>、<footer>、<address>、区块型元素(sectioningcontent)、标题型元素(headingcontent)
<address>
【1.7】子元素是一个<figcaption>元素,紧跟着流元素
<figure>
【1.8】子元素是一个<legend>元素,紧跟着流元素
<filedset>
【2】子元素是语句型元素
<h1>、<h2>、<h3>、<h4>、<h5>、<h6>、<p>、<pre>、<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>
【2.1】子元素是语句型元素,但不包括和自身相同的元素
<dfn>、<progress>、<meter>
【2.2】子元素是语句型元素,但不包括交互型元素(interactivecontent)
<button>
【3】子元素是transparent(以它的父元素允许的子元素为准)
<ins>、<del>、<map>
【3.1】子元素是transparent(以它的父元素允许的子元素为准),但不包括交互型元素(interactivecontent)
<a>
【3.2】子元素可以没有、可以是<param>元素,也可以是transparent(以它的父元素允许的子元素为准)
<object>
【4】无子元素
<hr>、<br>、<wbr>、<img>、<embed>、<param>、<source>、<track>、<area>、<col>、<keygen>
【4.1】子元素可以没有、可以是<li>元素,也可以是<script>、<template>元素
<ol>、<ul>
【4.2】子元素可以没有、可以是<dt>和<dd>元素,也可以是<script>、<template>元素
<dl>
【4.3】子元素可以没有,可以是<option>、<optgroup>,也可以是<script>、<template>元素
<select>
【4.4】子元素可以没有,可以是<option>,也可以是<script>、<template>元素
<optgroup>
【4.5】子元素可以没有、可以是<option>元素
<datalist>
【4.6】子元素可以没有、也可以是<track>元素,也可以是<source>元素
<audio>、<video>
【4.7】子元素可以没有,也可以是<col>、<template>元素
<colgroup>
【4.8】子元素可以没有,可以是<tr>,也可以是<script>、<template>元素
<tbody>、<thead>、<tfoot>
【4.9】子元素可以没有,可以是<tr>、<th>,也可以是<script>、<template>元素
<tr>
【5】子元素是<caption>、<colgroup>、<thead>、<tfoot>、<tbody>,也可以是<script>、<template>元素
<table>
【6】子元素是文本内容
<textarea>
【6.1】子元素可以没有,也可以是文本内容
<option>
总结关于每个元素的详细嵌套规则,上部分已经详细介绍。这部分主要对常用标签的嵌套规则进行总结[注意]将鼠标移动到深灰色背景的文字上,title将显示该元素所包含的标签
【1】<h1>、<h2>、<h3>、<h4>、<h5>、<h6>、<p>的子元素是语句型元素
【2】<header>、<footer>不可嵌套<header>、<footer>
【3】<a>的子元素是transparent(以它的父元素允许的子元素为准),但不包括交互型元素(interactivecontent)
【4】<form>不可嵌套<form>
【5】<button>子元素是语句型元素,不可嵌套交互型元素(interactivecontent)
【6】<caption>不可嵌套<table>
【7】<dt>、<th>不可嵌套<header>、<footer>、区块型元素(sectioningcontent)、标题型元素(headingcontent)
以上就是关于HTML5标签嵌套规则的详细介绍,最后如果你是零基础想要学习HTML5开发技术想要成为一名HTML5开发工程师的小伙伴通过自己的努力和老师的教导,在扣丁学堂参加完HTML5培训后想要找到一份不错的工作不是什么难事。扣丁学堂还有大量的HTML5视频教程供学员观看学习,喜欢HTML5开发想要进入HTML5开发领域的小伙伴不要再犹豫了,参加扣丁学堂HTML5培训让你的2018与众不同吧!扣丁学堂H5技术交流群:559883758。
【关注微信公众号获取更多学习资料】
查看更多关于“HTML5开发技术资讯”的相关文章>>
标签:
HTML5视频教程
HTML5全栈开发
HTML5培训
HTML5在线视频