DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> CSS入門知識 >> CSS進階教程 >> 你知道這些css網頁設計技巧嗎
你知道這些css網頁設計技巧嗎
編輯:CSS進階教程     

本翻譯並未得到作者或網站授權。一切權利都歸原作者及原網站所有。如果你得到原作者或原發表網站的授權,可以自由使用本翻譯。

1.CSS字體屬性簡寫規則

一般用CSS設定字體屬性是這樣做的:

font-weight:bold;
font-style:italic;
font-varient:small-caps;
font-size:1em;
line-height:1.5em;
font-family:verdana,sans-serif;

但也可以把它們全部寫到一行上去:

font: bold italic small-caps 1em/1.5em verdana,sans-serif;

真不錯!只有一點要提醒的:這種簡寫方法只有在同時指定font-size和font-family屬性時才起作用。而且,如果你沒有設定font-weight, font-style, 以及 font-varient ,他們會使用缺省值,這點要記上。

2. 同時使用兩個類

一般只能給一個元素設定一個類(Class),但這並不意味著不能用兩個。事實上,你可以這樣:

<p class="text side">...</p>

同時給P元素兩個類,中間用空格格開,這樣所有text和side兩個類的屬性都會加到P元素上來。如果它們兩個類中的屬性有沖突的話,後設置的起作用,即在CSS文件中放在後面的類的屬性起作用。

補充:對於一個ID,不能這樣寫<p id="text side">...</p>也不能這樣寫

3. CSS border的缺省值

通常可以設定邊界的顏色,寬度和風格,如:
border: 3px solid #000
這位把邊界顯示成3像素寬,黑色,實線。但實際上這裡只需要指定風格即可。

如果只指定了風格,其他屬性就會使用缺省值。一般地,Border的寬度缺省是medium,一般等於3到4個像素;缺省的顏色是其中文字的顏色。如果這個值正好合適的話,就不用設那麼多了。

1 2 3 4 5 下一頁



8. 用CSS來處理垂直對齊

垂直對齊用表格可以很方便地實現,設定表格單元 vertical-align: middle 就可以了。但對CSS來說這沒用。如果你想設定一個導航條是2em高,而想讓導航文字垂直居中的話,設定這個屬性是沒用的。

CSS方法是什麼呢?對了,把這些文字的行高設為 2em:line-height: 2em ,這就可以了。

9. CSS在容器內定位

CSS的一個好處是可以把一個元素任意定位,在一個容器內也可以。比如對這個容器:

#container { position: relative }

這樣容器內所有的元素都會相對定位,可以這樣用:
<div id="container"><div id="navigation">...</div></div>
如果想定位到距左30點,距上5點,可以這樣:

#navigation { position: absolute; left: 30px; top: 5px }

當然,你還可以這樣:
margin: 5px 0 0 30px
注意4個數字的順序是:上、右、下、左。當然,有時候定位的方法而不是邊距的方法更好些。

10. 直通到屏幕底部的背景色

在垂直方向是進行控制是CSS所不能的。如果你想讓導航欄和內容欄一樣直通到頁面底部,用表格是很方便的,但如果只用這樣的CSS:

#navigation { background: blue; width: 150px }

較短的導航條是不會直通到底部的,半路內容結束時它就結束了。該怎麼辦呢?

不幸的是,只能采用欺騙的手段了,給這較短的一欄加上個背景圖,寬度和欄寬一樣,並讓它的顏色和設定的背景色一樣。

body { background: url(blue-image.gif) 0 0 repeat-y }

此時不能用em做單位,因為那樣的話,一旦讀者改變了字體大小,這個花招就會露餡,只能使用px。
上一頁 1 2 3 4 5 下一頁



1. Block和inline元素對比
所有的HTML元素都屬於block和inline之一。
block元素的特點是:
總是在新行上開始;
高度,行高以及頂和底邊距都可控制;
寬度缺省是它的容器的100%,除非設定一個寬度
<div>, <p>, <h1>, <form>, <ul> 和 <li>是塊元素的例子。

相反地,inline元素的特點是:
和其他元素都在一行上;
高,行高及頂和底邊距不可改變;
寬度就是它的文字或圖片的寬度,不可改變。
<span>, <a>, <label>, <input>, <img>, <strong> 和<em>是inline元素的例子。

用display: inline 或display: block命令就可以改變一個元素的這一特性。什麼時候需要改變這一屬性呢?
讓一個inline元素從新行開始;
讓塊元素和其他元素保持在一行上;
控制inline元素的寬度(對導航條特別有用);
控制inline元素的高度;
無須設定寬度即可為一個塊元素設定與文字同寬的背景色。

2. 再來一個box黑客方法
之所以有這麼多box黑客方法,是因為IE在6之前對box的理解跟別人都不一樣,它的寬度要包含邊線寬和空白。要想讓IE5等同其他浏覽器保持一致,可以用CSS的方法:

padding: 2em;
border: 1em solid green;
width: 20em;
width/**/:/**/ 14em;

第一個寬度所有浏覽器都認得,但IE5.x不認得第2行的寬度設置,只因為那一行上有空白的注釋符號(多麼蠢的語法分析!),所以IE5.x就用20減掉一些空白,而其他浏覽器會用14這個寬度,因為它是第2行,會覆蓋掉第1行。

3. 頁面的最小寬度

min-width是個非常方便的CSS命令,它可以指定元素最小也不能小於某個寬度,這樣就能保證排版一直正確。但IE不認得這個,而它實際上把width當做最小寬度來使。為了讓這一命令在IE上也能用,可以把一個<div> 放到 <body> 標簽下,然後為div指定一個類:

<body>
<div class="container“>

然後CSS這樣設計:

#container
{
min-width: 600px;
width:expression(document.body.clientWidth < 600? "600px": "auto" );
}

第一個min-width是正常的;但第2行的width使用了Javascript,這只有IE才認得,這也會讓你的HTML文檔不太正規。它實際上通過Javascript的判斷來實現最小寬度。

同樣的辦法也可以為IE實現最大寬度:

#container
{
min-width: 600px;
max-width: 1200px;
width:expression(document.body.clientWidth < 600? "600px" : document.body.clientWidth > 1200? ”1200px“ : ”auto";
}

上一頁 1 2 3 4 5 下一頁



4. IE與寬度和高度的問題

IE不認得min-這個定義,但實際上它把正常的width和height當作有min的情況來使。這樣問題就大了,如果只用寬度和高度,正常的浏覽器裡這兩個值就不會變,如果只用min-width和min-height的話,IE下面根本等於沒有設置寬度和高度。

比如要設置背景圖片,這個寬度是比較重要的。要解決這個問題,可以這樣:

.box
{
width: 80px;
height: 35px;
}

html>body .box
{
width: auto;
height: auto;
min-width: 80px;
min-height: 35px;
}

所有的浏覽器都可以使用第一個box設置,但IE不認得第2段設置,因為其中用到了子選擇器命令。第2個設置更特殊些,所以它會覆蓋掉第1個設置。

5. 字體變形命令

text-transform 命令很有用,它有3個值:text-tran

12下一頁
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved