在CSS中,一個經(jīng)常被人們討論的先進之處即背景圖像的可層疊性,并允許他們在彼此之上進行滑動,以創(chuàng)造一些特殊的效果。根據(jù)CSS2.0當(dāng)前的規(guī)定,每一個背景圖像都需要各自的HTML元素。在許多情況下,典型的標(biāo)記已經(jīng)為一般的接口組件提供了多種元素以供我們使用。
標(biāo)簽導(dǎo)航欄就是其中的一個例子。過去,我們頻繁的使用這些標(biāo)簽,并已成為了一種非常流行的站點導(dǎo)航方式。現(xiàn)今,在CSS已被廣泛支持的前景下,我們可以為我們站點制作出更高質(zhì)量和更好外觀的標(biāo)簽導(dǎo)航欄來。你也許知道CSS可以用來“馴服”無序的列表,或許你還曾經(jīng)看到過這種樣式的標(biāo)簽列表:
如果我們想用和以上類似的標(biāo)記,將導(dǎo)航標(biāo)簽變成這種樣式,該怎么辦呢?
經(jīng)過簡單的設(shè)計,我們是可以做到的。
創(chuàng)新于何處?
我見過的許多基于CSS的導(dǎo)航標(biāo)簽大都具有一類的特征:矩形的色塊,也許僅僅是一個輪廓,對于當(dāng)前選中的標(biāo)簽則沒有邊框,標(biāo)簽在鼠標(biāo)指針游至其上時改變顏色。這難道就是CSS所能給我們的全部嗎?一連串的小盒子和單調(diào)的色彩嗎?
在CSS被廣泛采用之前,我們已經(jīng)看到許多標(biāo)簽導(dǎo)航設(shè)計中的創(chuàng)新之處。獨創(chuàng)的外形,熟練的色彩混合,以及對真實世界中許多物理接口的模仿。但是這些設(shè)計往往過分依賴于經(jīng)過復(fù)雜制作、帶有文本的圖像,或被包裝成若干嵌套的表格。修改文本或改變標(biāo)簽的順序則需要一個復(fù)雜的過程。文本的伸縮更是不可能的,或給頁面的布局極大的影響。
純文本的導(dǎo)航欄比起文本即圖像的導(dǎo)航欄更具有持續(xù)使用性和更快的載入速度。同樣,我們甚至可以為每一個圖像加上alt屬性,對于弱視者,純文本更可以自由的改變大小。不足為奇的是,基于純文本的導(dǎo)航欄,并加以CSS樣式,又重新回到Web設(shè)計中來。但是,大多數(shù)基于CSS的導(dǎo)航欄設(shè)計,至今為止仍然是毫無意義的。一種最近被采用的技術(shù)(例如CSS)可以讓我們做的更好,同樣不失先前提到的那些表格和圖片標(biāo)簽的效果。
滑動門技術(shù)
美觀的工藝,真正靈活的接口組件,并根據(jù)文本自適應(yīng)大小,我們可用兩個獨立的背景圖像來創(chuàng)造它。一個在左邊,一個在右邊。把這兩幅圖像想象成兩扇可滑動的門,它們滑到一起并交迭,占據(jù)一個較窄的空間;或者相互滑開,占據(jù)一個較寬的空間,就像下圖所顯示的那樣:
在這個模型中,一個圖像掩蓋住另一個圖片的一部分。假設(shè)我們放置一些獨特的內(nèi)容在每個圖像的周圍,例如標(biāo)簽的圓角,我們并不希望上面一副圖像完全的遮蔽住下面一副。為了防止這種情況的發(fā)生,我們可以將上面一副圖像(此例中的左邊那幅)控制的盡可能的窄。但仍然要保證一定的寬度來顯現(xiàn)標(biāo)簽一側(cè)的獨特性。如果外部是圓角,我們就應(yīng)該控制上面一副圖像和它的弧線部分具有一樣的寬度。
如果目標(biāo)在大小上增長,并超過了以上所顯示的寬度,歸咎于文本大小及字體的改變,圖像會被拉開,產(chǎn)生不美觀的間隙。我們需要判斷的是,預(yù)測這種可擴展的量將有多大。如果在瀏覽器中改變字體的大小,目標(biāo)又會如果增長呢?實際來說,我們至少應(yīng)該估算到字體大小增長至300%的情況。背景圖像也得適應(yīng)這種增長。對于以上的例子,我們將下面(即右邊)的圖像設(shè)為400*150像素,上面的設(shè)為9*150像素。
在頭腦中,始終要有這樣的認識:背景圖像只是顯示一個可供內(nèi)容填充的有效空間(即內(nèi)容區(qū)域和padding,稱為doorway)。這兩幅圖像始終和各自外部的邊角相錨定。背景圖像的可見部分和在一起即形成了一個具有這種標(biāo)簽形狀的空間(doorway):
如果標(biāo)簽被撐大,圖像即滑開,doorway變寬,圖像的也將被顯露的更多:
此例中,我在photoshop中制作兩個平滑,細的3D標(biāo)簽圖像,如文章開頭所顯示的那樣。對于其一,內(nèi)部明亮,邊框暗淡些,用來表現(xiàn)當(dāng)前選中的標(biāo)簽。將這種技巧模型應(yīng)用于左右兩幅圖像中,我們需要擴大標(biāo)簽圖像覆蓋的區(qū)域,將它裁剪成兩部分:
同樣的方式將應(yīng)用到被稱為“當(dāng)前”的標(biāo)簽中。一旦我們完成了這四幅圖像(1, 2, 3, 4),我們就可以開始用標(biāo)記和CSS來制作我們的標(biāo)簽了。
標(biāo)簽的創(chuàng)造
當(dāng)你在研究用CSS來創(chuàng)造水平列表時,會發(fā)現(xiàn)至少有兩種方法將列表項安排在同一行里。兩種方法各有千秋,但都需要CSS來解決布局所帶來的混亂。一種方法使用inline box,另一種則用floats。
方法一,可能是比較普遍的一種,是將列表項都inline顯示。inline方法的魅力在于它的簡易性。但是,對于我們即將談到的滑動門技術(shù)來說,inline方法在特定的瀏覽器上存在一些解釋上問題。方法二,是我們將要關(guān)注的,即用floats將列表項安排在同一行里。令人沮喪的是,floats表面上矛盾的行為正巧回避了自然的邏輯。盡管如此,對于解決多重浮動元素的基本認識,以及可靠浮動的意義,仍是值得討論的。
我們將用另一種浮動元素來解決浮動元素的排列問題。這樣,父類元素將子類元素完全包括起來。于是,我們就可以為標(biāo)簽加上背景色彩和背景圖像。非常重要的一點必須記住,緊跟在標(biāo)簽后的文本元素用CSS中的clear功能來清除浮動對象。這樣避免了浮動標(biāo)簽影響頁面上其它元素的位置。
我們從以下的標(biāo)記開始:
<div id="header">
<ul>
<li><a href="#">Home</a></li>
<li id="current"><a href="#">News</a></li>
<li><a href="#">Products</a></li>
<li><a href="#">About</a></li>
<li><a href="#">Contact</a></li>
</ul>
</div>
現(xiàn)實中,#header div可能同樣包含logo和搜索框。對于我們的例子,我們要縮短每一個錨鏈中超鏈接的值。顯然,這些值應(yīng)該正確的包含文件或者目錄的位置。
我們從定位#header容器開始設(shè)計列表。這樣確保了這個容器確確實實的充當(dāng)了容器的作用,以包容它內(nèi)部浮動的列表項。既然元素是浮動的,我們同樣需要聲明它的寬度為100%。加入臨時的黃色背景以確保父類容器完全填滿標(biāo)簽后面的整個區(qū)域。同樣,設(shè)定默認的文本屬性,確保樣式的統(tǒng)一:
#header {
float:left;
width:100%;
background:yellow;
font-size:93%;
line-height:normal;
}
現(xiàn)在,我們同樣需要為無序列表設(shè)定默認的margin/padding值為0,并去掉列表項前面的標(biāo)記。每個列表項左浮動:
#header ul {
margin:0;
padding:0;
list-style:none;
}
#header li {
float:left;
margin:0;
padding:0;
}
設(shè)定錨鏈強制作為塊對象呈遞,我們便可無憂的控制所有的樣式:
#header a {
display:block;
}
下一步,我們將右側(cè)的背景圖像加入到列表項中去(改變?nèi)绱煮w所示):
#header li {
float:left;
background:url("norm_right.gif")
no-repeat right top;
margin:0;
padding:0;
}
在加入左側(cè)圖像之前,我們可以在效果1種看看目前為止的效果。(在效果中,忽略body中的規(guī)則。僅設(shè)定基本margin,padding,colors,text的屬性。)
---
現(xiàn)在我們可以將左側(cè)圖像放置在錨鏈的左邊(容器內(nèi)的元素)。我們同時加入padding,擴大標(biāo)簽并將文本從標(biāo)簽的邊緣推開:
#header a {
display:block;
background:url("norm_left.gif")
no-repeat left top;
padding:5px 15px;
}
這樣我們就得到了效果2。注意我們的標(biāo)簽是如何成型的。在這里,IE5/Mac的用戶會立刻驚奇道,“天啊,我的標(biāo)簽垂直堆在一起并且延伸至整個屏幕!”不要著急,我們馬上幫你解決。眼下,盡量按照下面去做,或者方便的話,臨時改換其他的瀏覽器,并且IE5/Mac版本的問題會馬上得到解決。
本文來源于成都網(wǎng)站建設(shè)公司與成都網(wǎng)站設(shè)計制作公司-創(chuàng)新互聯(lián)成都公司!
本文名稱:CSS中的滑動門技術(shù)
文章URL:http://m.rwnh.cn/news23/312323.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、網(wǎng)站收錄、手機網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、品牌網(wǎng)站制作、做網(wǎng)站
廣告
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源:
創(chuàng)新互聯(lián)