網(wǎng)站建設CSS2引入了一個(gè)值run-in,這也是一個(gè)有意思的塊/行內元素混合,可以使某些塊級元素成為下一個(gè)元素的行內部分,這種功能對于某些標題效果很有用,這在打印排版中相當常見(jiàn),即標題作為文本段落的一部分出現。在網(wǎng)站建設CSS中,只需改變元素的display值,并使下一個(gè)元素框作為塊級元素框,就可以使元素成為run-in元素。注意,這里我所說(shuō)的是框,而不是元素本身。換句話(huà)說(shuō),不論元素是塊元素還是行內元素都無(wú)關(guān)緊要,重要的是元素生成的框。設置為display: block的strong元素會(huì )生成一個(gè)塊級框,設置為display: inline的段落則會(huì )生成一個(gè)行內框。
所以,重申一句:如果一個(gè)元素生成run-in框,而且該框后面是一個(gè)塊級框,那么該run-in元素將成為塊級框開(kāi)始處的一個(gè)行內框。例如:
<h3 style="display: run-in; border: 1px dotted; font-size: 125%;
font-weight: bold;">Run-in Elements</h3>
<p style="border-top: 1px solid black; padding-top: 0.5em;">
Another interesting block/inline hybrid is the value <code>run-in</code>,
introduced in CSS2, which has the ability to take block-level elements and
make them an inline part of a following element. This is useful for certain
heading effects that are quite common in print typography, where a heading
will appear as part of a paragraph of text.
</p>
由于h3后面的元素生成一個(gè)塊級框,所以h3元素將變成p元素內容開(kāi)始處的一個(gè)行內元素。
注意兩個(gè)元素的邊框是如何放置的。這種情況下使用run-in的效果與使用以下標記完全相同:
<p style="border-top: 1px solid black; padding-top: 0.5em;">
<span style="border: 1px dotted; font-size: 125%; font-weight: bold;">Run-in
Elements</span> Another interesting block/inline hybrid is the value
<code>run-in</code>, introduced in CSS2, which has the ability to take
block-level elements and make them an inline part of a following element.
This is useful for certain heading effects that are quite common in print
typography, where a heading will appear as part of a paragraph of text.
</p>
不過(guò),網(wǎng)頁(yè)設計中run-in框與前面的標記示例之間還存在一個(gè)小小的差別。即使run-in框格式化為另一個(gè)元素中的行內框,它們仍從文檔中的父元素繼承屬性,而不是說(shuō)它們放在哪個(gè)元素中就從哪個(gè)元素繼承屬性。再來(lái)擴展前面的例子,在最外面加一個(gè)div,并增加一些顏色:
<div style="color: silver;">
<h3 style="display: run-in; border: 1px dotted; font-size: 125%;
font-weight: bold;">Run-in Elements</h3>
<p style="border-top: 1px solid black; padding-top: 0.5em; color: black;">
Another interesting block/inline hybrid is the value <code>run-in</code>,
introduced in CSS2, which has the ability to take block-level elements and
make them an inline part of a following element.
</p>
</div>
在這種情況下,h3將是銀色而不是黑色,如圖7-54所示。這是因為在插入到段落之前,它從其父元素(div)繼承了顏色值。要記住重要的一點(diǎn),只有當run-in框后面是一個(gè)塊級框時(shí)run-in才起作用。如果不是這樣,run-in框本身將成為塊級框。因此,給定以下標記,h3仍然是(或者會(huì )變成)塊級元素,因為table元素的display值是(非常奇怪)table:
<h3 style="display: run-in;">Prices</h3>
<table>
<tr><th>Apples</th><td>$0.59</td></tr>
<tr><th>Peaches</th><td>$0.79</td></tr>
<tr><th>Pumpkin</th><td>$1. 29</td></tr>
<tr><th>Pie</th><td>$6.99</td></tr>
</table>
網(wǎng)頁(yè)設計人員不太可能將值run-in應用到一個(gè)自然的行內元素,但是一旦發(fā)生這種情況,這個(gè)元素則極有可能生成一個(gè)塊級框。例如,以下標記中的em元素將成為塊級元素,因為它后面沒(méi)有跟一個(gè)塊級框:
<p>
This is a <em>really</em> odd thing to do,<strong>but</strong> you could do it
if you were so inclined.
</p>
警告:寫(xiě)作本書(shū)時(shí),很少有瀏覽器對run-in提供支持。
如果元素是浮動(dòng)元素或定位元素,display的計算值可以改變。如果為一個(gè)根元素聲明display值,計算值也可以改變。實(shí)際上,display、position和float值會(huì )以很有意思的方式相互影響。
如果一個(gè)元素是絕對定位元素,float的值設置為none。對于浮動(dòng)元素或絕對定位素,計算值由聲明值確定。
inline-table
table
inline, run-in, table-row-group, table-column, table-column -group,
table-header-group, table-footer-group, table-row, table-cell, table-caption, inline-block
block
所有其他 根據指定確定
對于根元素,如果聲明為值inline-table或table,都會(huì )得到計算值table,聲明為none時(shí)則會(huì )得到同樣的計算值(none)。所有其他display值都計算為block。
盡管網(wǎng)站建設CSS格式化模型的某些方面乍看起來(lái)有些不太直觀(guān),不過(guò)等你多熟悉一些就會(huì )發(fā)現這是有道理的。很多情況下,最初看上去沒(méi)道理甚至荒謬的規則最后看來(lái)確實(shí)是合理的,它們會(huì )防止一些奇怪的或我們不期望的文檔顯示結果。在很多方面,塊級元素都很容易理解。調整其布局通常是一個(gè)簡(jiǎn)單的任務(wù)。另一方面,行內元素則可能很難管理,因為有很多影響因素,其中也包括元素是替換元素還是非替換元素。既然我們已經(jīng)對文檔布局的基礎知識有所了解,下面再來(lái)關(guān)注如何使用各種布局屬性。后面的幾章都在討論這個(gè)方面,首先來(lái)看最常用的框屬性:內邊距、邊框和外邊距。
【注釋】
[1] 譯注1:嚴格地說(shuō),需求應該是“元素的7項水平屬性的總和”不能比其包含塊更寬。
當前文章標題:網(wǎng)頁(yè)設計中的run-in元素
當前URL:http://amzcoolest.com/news/wzzz/run-in.html