html标签嵌套规则

我们知道js代码如果有语法错误,浏览器会拒绝执行并报错。但是!浏览器遇到不合法的html时不会报错,会千方百计地把它渲染出来。

XHTML 标签的嵌套规则了:

1. 块元素可以包含内联元素或某些块元素,但内联元素却不能包含块元素,它只能包含其它的内联元素:

<div><h1></h1><p></p></div> —— 对

<a href=”#”><span></span></a> —— 对

<span><div></div></span> —— 错

2. 块级元素不能放在<p>里面:

<p><ol><li></li></ol></p> —— 错

<p><div></div></p> —— 错

3. 有几个特殊的块级元素只能包含内嵌元素,不能再包含块级元素,这几个特殊的标签是:

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

4. li 内可以包含 div 标签 —— 这一条其实不必单独列出来的,但是网上许多人对此有些疑惑,就在这里略加说明:

li 和 div 标签都是装载内容的容器,地位平等,没有级别之分(例如:h1、h2 这样森严的等级制度^_^),要知道,li 标签连它的父级 ul 或者是 ol 都可以容纳的,为什么有人会觉得 li 偏偏容纳不下一个 div 呢?别把 li 看得那么小气嘛,别看 li 长得挺瘦小,其实 li 的胸襟很大滴……

5. 块级元素与块级元素并列、内嵌元素与内嵌元素并列:

<div><h2></h2><p></p></div> —— 对

<div><a href=”#”></a><span></span></div> —— 对

<div><h2></h2><span></span></div> —— 错

总体来说:块级元素能嵌入内联元素和部分块级元素,内联元素只能嵌入内联元素。

1、只能嵌入内联元素的块级元素:h1~h6, p, dt

2、li元素可以嵌入ul, ol, div

下面有几个典型的错误:

1.开始与结束标签嵌套错误;

 <div><h2>标题</div></h2>

2.p元素嵌套div

<p>
    <div>好的</div>
</p>

3.列表元素li的兄弟元素为div

<ul>
            <li>天上下凡三圣母</li>
            <div>沉香日夜哭着要寻母</div>
        </ul>

4.a元素嵌套a元素

<a href=""><a href="">链接</a></a>

5.h元素嵌套div元素

<h1><div>标题</div></h1>