網(wǎng)頁設(shè)計中的run-in元素

run-in元素

網(wǎng)站建設(shè)CSS2引入了一個值run-in,這也是一個有意思的塊/行內(nèi)元素混合,可以使某些塊級元素成為下一個元素的行內(nèi)部分,這種功能對于某些標(biāo)題效果很有用,這在打印排版中相當(dāng)常見,即標(biāo)題作為文本段落的一部分出現(xiàn)。在網(wǎng)站建設(shè)CSS中,只需改變元素的display值,并使下一個元素框作為塊級元素框,就可以使元素成為run-in元素。注意,這里我所說的是框,而不是元素本身。換句話說,不論元素是塊元素還是行內(nèi)元素都無關(guān)緊要,重要的是元素生成的框。設(shè)置為display: block的strong元素會生成一個塊級框,設(shè)置為display: inline的段落則會生成一個行內(nèi)框。

所以,重申一句:如果一個元素生成run-in框,而且該框后面是一個塊級框,那么該run-in元素將成為塊級框開始處的一個行內(nèi)框。例如:

<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后面的元素生成一個塊級框,所以h3元素將變成p元素內(nèi)容開始處的一個行內(nèi)元素。

注意兩個元素的邊框是如何放置的。這種情況下使用run-in的效果與使用以下標(biāo)記完全相同:

<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>

不過,網(wǎng)頁設(shè)計中run-in框與前面的標(biāo)記示例之間還存在一個小小的差別。即使run-in框格式化為另一個元素中的行內(nèi)框,它們?nèi)詮奈臋n中的父元素繼承屬性,而不是說它們放在哪個元素中就從哪個元素繼承屬性。再來擴展前面的例子,在最外面加一個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)繼承了顏色值。要記住重要的一點,只有當(dāng)run-in框后面是一個塊級框時run-in才起作用。如果不是這樣,run-in框本身將成為塊級框。因此,給定以下標(biāo)記,h3仍然是(或者會變成)塊級元素,因為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)頁設(shè)計人員不太可能將值run-in應(yīng)用到一個自然的行內(nèi)元素,但是一旦發(fā)生這種情況,這個元素則極有可能生成一個塊級框。例如,以下標(biāo)記中的em元素將成為塊級元素,因為它后面沒有跟一個塊級框:

<p>

This is a <em>really</em> odd thing to do,<strong>but</strong> you could do it

if you were so inclined.

</p>

警告:寫作本書時,很少有瀏覽器對run-in提供支持。

計算值

如果元素是浮動元素或定位元素,display的計算值可以改變。如果為一個根元素聲明display值,計算值也可以改變。實際上,display、position和float值會以很有意思的方式相互影響。

如果一個元素是絕對定位元素,float的值設(shè)置為none。對于浮動元素或絕對定位素,計算值由聲明值確定。

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

所有其他  根據(jù)指定確定

對于根元素,如果聲明為值inline-table或table,都會得到計算值table,聲明為none時則會得到同樣的計算值(none)。所有其他display值都計算為block。

小結(jié)

盡管網(wǎng)站建設(shè)CSS格式化模型的某些方面乍看起來有些不太直觀,不過等你多熟悉一些就會發(fā)現(xiàn)這是有道理的。很多情況下,最初看上去沒道理甚至荒謬的規(guī)則最后看來確實是合理的,它們會防止一些奇怪的或我們不期望的文檔顯示結(jié)果。在很多方面,塊級元素都很容易理解。調(diào)整其布局通常是一個簡單的任務(wù)。另一方面,行內(nèi)元素則可能很難管理,因為有很多影響因素,其中也包括元素是替換元素還是非替換元素。既然我們已經(jīng)對文檔布局的基礎(chǔ)知識有所了解,下面再來關(guān)注如何使用各種布局屬性。后面的幾章都在討論這個方面,首先來看最常用的框?qū)傩裕簝?nèi)邊距、邊框和外邊距。

  【注釋】

  [1] 譯注1:嚴格地說,需求應(yīng)該是“元素的7項水平屬性的總和”不能比其包含塊更寬。

網(wǎng)站建設(shè)、網(wǎng)絡(luò)營銷咨詢專線:0871-63535511(點擊可一鍵撥號)