ホームページ > 記事 > ウェブフロントエンド > HTML要素の入れ子の問題
特定の
ブロック要素を含めることができますが、インライン要素にはブロック要素を含めることはできず、他のインライン要素のみを含めることができます。 某些
块元素,但内联元素却不能包含块元素,只能包含其他的内联元素。
<p> <p></p> </p><p>在P元素中嵌套p等块级元素,在浏览器中解析如下: <p> <p>可以看到在元素最后会多出一个空的
<p></p>
。
<p>通过查询,发现原来p元素
内无法包裹块级元素
。块级元素
是不能放在<p>
里面的,再加上一些浏览器纵容这样的写法:
<p>这是一个段落的开始 <p>这是另一个段落的开始<p>当一个
<p>
标签还没结束时,遇到下一个块元素就会把自己结束掉,其实浏览器是把它们处理成这样:
<p>这是一个段落的开始</p> <p>这是另一个段落的开始</p><p>这也就解释了,为何浏览器中最后会多出1个空的
<p></p>
。
<html>
是在最外层,<html>
下一级里面只会有<head>、<body>、<frameset>、<noframes>
,而我们已经知道了可视的元素只会出现在<body>
里,所以我们把<body>
划在第一个级里面。接着,把不可以自由嵌套
的元素划在第三个级,其他的就归进第二个级。所谓的不可自由嵌套的元素就是里面只能放内联元素的,它们包括有:标题标记的<h1>、<h2>、<h3>、<h4>、<h5>、<h6>、<caption>
;段落标记的<p>
;分隔线<hr>
和一个特别的元素<dt>
(它只存在于列表元素<dl>
的子一级)。
<p>三级元素
就是指,只能嵌套内联元素的块级元素。p
也恰好是其中之一。
<ul>
嵌在<p>
里面,也可以把<p>
嵌在<li>
里面。
<p>在HTML里有几个元素是比较特别的:<ul>、、<dl>、<table>
,它们的子一层必须是指定元素,<ul>、>的子一级必须是<li>
;<dl>
的子一级必须是<dt>
或者<dd>
;<table>
的子一层必须是<caption>
或<thead>、<tfoot>、<tbody>
等,而再子一层必须是<tr>
(<tr>
只存在于<thead>、<tfoot>、<tbody>
中),之后才是可放内容的<td>
或者<th>
。
<img>、<input>
等)比较特别,它们可以定义宽高。虽然在IE
浏览器里,所有的元素都可以定义宽高,但这是IE
自己的标准,并非所有浏览器都支持,W3C
それは最後に表示されます。要素 余分な空の <p></p>
が存在します。
p 要素
は block-level 要素
をラップできないことがわかりました。 🎜なぜなら、私たちが使用する DTD では、ブロックレベル要素
を <p>
内に配置できないと規定しており、一部のブラウザではそのような記述を容認しているからです。 <p> タグは終了していません。次のブロック要素に遭遇すると自動的に終了します。実際、ブラウザは次のように処理します: 🎜rrreee🎜これは、なぜ余分な空の があるのかについても説明しています。最後にブラウザで <p></p>
をクリックします。 🎜🎜ブロックレベル要素のネスト問題🎜🎜 まず、すべてのブロック要素を再度複数のレベルに分割できます。<html>
が最外層の <html> にあることはすでにわかっています。
次のレベルには <head>、<body>、<frameset>、<noframes>
のみがあり、表示される要素はのみであることがすでにわかっています。 <body>
に出現するため、<body>
を最初のレベルに置きます。次に、自由にネストできない要素
を第 3 レベルに、その他を第 2 レベルに配置します。自由にネストできないいわゆる要素には、インライン要素のみを含めることができます。これには、タイトル タグ 、、、 が含まれます。 ;、、<caption>
; 段落タグ <p>
; 区切り文字 <hr>
および特殊要素 < ;dt>
(リスト要素 <dl>
の子レベルにのみ存在します)。 🎜🎜第 3 レベルの要素
は、インライン要素のみをネストできるブロックレベルの要素を指します。 p
もその 1 つです。 🎜🎜第 2 レベルの要素が自由に入れ子にできる理由🎜🎜これらをいくつかのコンテナ (またはボックス) として考えることができ、これらのコンテナのサイズは自由に変更できます。たとえば、<ul> を置くことができます。 は <p>
に埋め込まれます。または、<p>
は <li>
に埋め込むことができます。 🎜🎜 HTML にはいくつかの特別な要素があります: <ul>、、<dl>、<table>
、それらのサブレベルは指定された要素である必要があります。 <ul>、> は <li>
の子レベルである必要があります。 レベルは次のとおりです。 <dt>
または <dd>
; <table>
のサブレベルは <caption>
である必要があります。 > または <thead>、<tfoot>、<tbody>
など。次のサブレベルは <tr>
である必要があります ( <tr>
は、<thead>、<tfoot>、<tbody>
にのみ存在し、その後、コンテンツを配置できる <td> にのみ存在します。 /code> または <th>。 🎜🎜インライン要素🎜🎜実際、インライン要素は依然として区別でき、幅を定義できる特別な要素がいくつかあります。身長。 IE
ブラウザではすべての要素で幅と高さを定義できますが、これは IE
独自の標準であり、すべてのブラウザが W3C
をサポートしているわけではありません。 >これらを置換要素と呼びます。実際、これらの要素はインラインですが、特定のブロックを持っています (幅と高さを設定することもできます)。 :inline -ブロック。 🎜要素自体に inline-block が含まれていてはなりません。 🎜🎜HTML 要素のネストの問題の詳細については、PHP 中国語 Web サイトの関連記事に注目してください。 🎜🎜🎜🎜🎜