天天看點

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檔案中放在後面的類的屬性起作用。

3. CSS border的預設值

通常可以設定邊界的顔色,寬度和風格,如:

border: 3px solid #000

這位把邊界顯示成3像素寬,黑色,實線。但實際上這裡隻需要指定風格即可。

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

4. CSS用于文檔列印

許多網站上都有一個針對列印的版本,但實際上這并不需要,因為可以用CSS來設定列印風格。

也就是說,可以為頁面指定兩個CSS檔案,一個用于螢幕顯示,一個用于列印:

<link type="text/css" rel="stylesheet" href="stylesheet.css" media="screen" /> <link type="text/css" rel="stylesheet" href="printstyle.css" media="print" />

第1行就是顯示,第2行是列印,注意其中的media屬性。

但應該在列印CSS中寫什麼東西呢?你可以按設計普通CSS的方法來設定它。設計的同時就可以把這個CSS設成顯示CSS來檢查它的效果。也許你會使用

display: none

這個指令來關掉一些裝飾圖檔,再關掉一些導航按鈕。要想了解更多,可以看“列印差異”這一篇。

5. 圖檔替換技巧

一般都建議用标準的HTML來顯示文字,而不要使用圖檔,這樣不但快,也更具可讀性。但如果你想用一些特殊字型時,就隻能用圖檔了。

比如你想整個賣東西的圖示,你就用了這個圖檔:

<h1><img src="widget-p_w_picpath.gif" alt="Buy widgets" /></h1>

這當然可以,但對搜尋引擎來說,和正常文字相比,它們對alt裡面的替換文字幾乎沒有興趣這是因為許多設計者在這裡放許多關鍵詞來騙搜尋引擎。是以方法應該是這樣的:

<h1>Buy widgets</h1>

但這樣就沒有特殊字型了。要想達到同樣效果,可以這樣設計CSS:

h1 { background: url(widget-p_w_picpath.gif) no-repeat; height: p_w_picpath height text-indent: -2000px }

注意把p_w_picpath height換成真的圖檔的高度。這裡,圖檔會當作背景顯示出來,而真正的文字由于設定了-2000像素這個縮進,它們會出現在螢幕左邊2000點的地方,就看不見了。但這對于關閉圖檔的人來說,可能全部看不到了,這點要注意。

6. CSS box模型的另一種調整技巧

這個Box模型的調整主要是針對IE6之前的IE浏覽器的,它們把邊界寬度和空白都算在元素寬度上。比如:

#box { width: 100px; border: 5px; padding: 20px }

這樣調用它:

<div id="box">...</div>

這時盒子的全寬應該是150點,這在除IE6之前的IE浏覽器之外的所有浏覽器上都是正确的。但在IE5這樣的浏覽器上,它的全寬仍是100點。可以用以前人發明的Box調整方法來處理這種差異。

但用CSS也可以達到同樣的目的,讓它們顯示效果一緻。

#box { width: 150px } #box div { border: 5px; padding: 20px }

這樣調用:

<div id="box"><div>...</div></div>

這樣,不管什麼浏覽器,寬度都是150點了。

7. 塊元素居中對齊

如果想做個固定寬度的網頁并且想讓網頁水準居中的話,通常是這樣:

#content { width: 700px; margin: 0 auto }

你會使用

<div id="content">

來圍上所有元素。這很簡單,但不夠好,IE6之前版本會顯示不出這種效果。改CSS如下:

body { text-align: center } #content { text-align: left; width: 700px; margin: 0 auto }

這會把網頁内容都居中,是以在Content中又加入了

text-align: left

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-p_w_picpath.gif) 0 0 repeat-y }

此時不能用em做機關,因為那樣的話,一旦讀者改變了字型大小,這個花招就會露餡,隻能使用px。

1. Block和inline元素對比

所有的HTML元素都屬于block和inline之一。block元素的特點是:

  • 總是在新行上開始;
  • 高度,行高以及頂和底邊距都可控制;
  • 寬度預設是它的容器的100%,除非設定一個寬度

<div>

,

<p>

<h1>

<form>

<ul>

<li>

是塊元素的例子。相反地,inline元素的特點是:

  • 和其他元素都在一行上;
  • 高,行高及頂和底邊距不可改變;
  • 寬度就是它的文字或圖檔的寬度,不可改變。

<span>

<a>

<label>

<input>

<img>

<strong>

<em>

是inline元素的例子。

用code class="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"); }

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-transform: uppercase

text-transform: lowercase

text-transform: capitalize

。第1個會把文字變成全大寫,第2個變成全小寫,第3個變成首字母大寫。這對拼音文字非常有用,即使輸入時有大小寫錯誤,在網頁上也看不到。

6. IE中圖檔文字消失的問題

有時會遇到文字或背景圖突然消失的問題,重新整理一下又出現了,這在靠近漂浮元素時更容易發生(注:沒見過)。此時,可以為消失的元素設定:

position: relative

,如果不行,再考慮為這些元素指定一個寬度試試。

7. 不可見文字

不論因為何種原因希望某些網頁文字不在浏覽器中顯示,比如為了列印或為了小螢幕而讓某些文字不顯示,都可以用

display: none

。這非常簡單,但有時對某些人這有點沒用,他們能去掉這個控制,這時就要用到:

position: absolute; left: -9000px

這實際上是把文字指定在頁面以外顯示。

8. 為手持裝置設計專門的CSS

也就是手機/PDA等小螢幕使用者,可以專門設計一個CSS來讓網頁顯示更舒服些。為此,可以把浏覽器視窗調整到150點寬來看效果。指定專門的手持裝置的CSS的文法是:

<link type="text/css" rel="stylesheet" href="handheldstyle.css" media="handheld" />

也可以閱讀專門的手持裝置可用性。

9. 3D效果的按鈕

以前要想制作帶有3D效果,并且點選下去還會變化的按鈕,就得用圖檔替換的方法,現在CSS就可以了:

a { display: block; border: 1px solid; border-color: #aaa #000 #000 #aaa; width: 8em; background: #fc0; } a:hover { position: relative; top: 1px; left: 1px; border-color: #000 #aaa #aaa #000; }

至于效果,還可以自己調整了。

10. 在不同頁面上使用同樣的導航代碼

許多網頁上都有導航菜單,當進入某頁時,菜單上相應這一項就應該變灰,而其他頁亮起來。一般要實作這個效果,需要寫程式或專門為每一頁做設計,現在靠CSS就可以實作這個效果。

首先,在導航代碼中使用CSS類:

<ul> <li><a href="#" class="home">Home</a></li> <li><a href="#" class="about">About us</a></li> <li><a href="#" class="contact">Contact us</a></li> </ul>

然後分别為每一頁的Body指定一個id,和上面類同名。如

<body id="contact">

然後設計CSS如下:

#home .home, #about .about, #about .about { commands for highlighted navigation go here }

這裡,當id設為home時,.home就會起作用,也就是class設為home的那一行導覽列就會顯示出特殊效果來。其他頁也是如此。

轉至[url]http://www.cnblogs.com/circlesport/archive/2007/02/03/638827.html[/url]