新聞中心
本文和大家重點(diǎn)討論一下CSS樣式表設(shè)計(jì)十個(gè)雕蟲小技,比如說圖片替換的技巧,使用標(biāo)準(zhǔn)的html而不是圖片來顯示文字通常更為明智,除了加快下載還可以獲得更好的可用性,相信本文介紹一定會讓你有所收獲。

創(chuàng)新互聯(lián)公司"三網(wǎng)合一"的企業(yè)建站思路。企業(yè)可建設(shè)擁有電腦版、微信版、手機(jī)版的企業(yè)網(wǎng)站。實(shí)現(xiàn)跨屏營銷,產(chǎn)品發(fā)布一步更新,電腦網(wǎng)絡(luò)+移動(dòng)網(wǎng)絡(luò)一網(wǎng)打盡,滿足企業(yè)的營銷需求!創(chuàng)新互聯(lián)公司具備承接各種類型的成都網(wǎng)站設(shè)計(jì)、做網(wǎng)站項(xiàng)目的能力。經(jīng)過10多年的努力的開拓,為不同行業(yè)的企事業(yè)單位提供了優(yōu)質(zhì)的服務(wù),并獲得了客戶的一致好評。
CSS樣式表設(shè)計(jì)之10條技巧
1.CSS字體簡寫規(guī)則
當(dāng)使用CSS定義字體時(shí)你可能會這樣做:
ExampleSourceCode
- font-size:1em;
- line-height:1.5em;
- font-weight:bold;
- font-style:italic;
- font-variant:small-caps;
- font-family:verdana,serif;
事實(shí)上你可以簡寫這些屬性:
- font:1em/1.5embolditalicsmall-capsverdana,serif
現(xiàn)在好多了吧,不過有一點(diǎn)要注意:使用這一簡寫方式你至少要指定font-size和font-family屬性,其他的屬性(如font-weight,font-style,font-varient)如未指定將自動(dòng)使用默認(rèn)值。
2.同時(shí)使用兩個(gè)class
通常我們只為屬性指定一個(gè)class,但這并不等于你只能指定一個(gè),實(shí)際上,你想指定多少就可以指定多少,例如:
3.CSS中邊框(border)的默認(rèn)值
當(dāng)編寫一條邊框的規(guī)則時(shí),你通常會指定顏色、寬度以及樣式(任何順序均可)。例如:border:3pxsolid#000(3像素寬的黑色實(shí)線邊框),其實(shí)這個(gè)例子中唯一需要指定的值只是樣式。假如你指定樣式為實(shí)線(solid),那么其余的值將使用默認(rèn)值:默認(rèn)的寬度為中等(相當(dāng)于3到4像素);默認(rèn)的顏色為邊框里的文字顏色。如果這正是你想要的效果,你完全可以不在CSS里指定。
4.!important會被IE忽略
在CSS樣式表中,通常最后指定的規(guī)則會獲得優(yōu)先權(quán)。然而對除了IE以外的瀏覽器來說,任何后面標(biāo)有!important的語句將獲得絕對的優(yōu)先權(quán),例如:margin-top:3.5em!important;margin-top:2em除IE以外所有瀏覽器中的頂部邊界都是3.5em,而IE為2em,有時(shí)候這一點(diǎn)很有用,尤其在使用相對邊界值時(shí)(就像這個(gè)例子),可以顯示出IE與其他瀏覽器的細(xì)微差別。(很多人可能還注意到了CSS的子選擇器也是會被IE忽略的)。#p#
5.圖片替換的技巧
使用標(biāo)準(zhǔn)的html而不是圖片來顯示文字通常更為明智,除了加快下載還可以獲得更好的可用性。但是如果你決心使用訪問者的機(jī)器中可能沒有的字體時(shí),你只能選擇圖片。
舉例來說,你想在每一頁的頂部使用“Buywidgets”的標(biāo)題,但你同時(shí)又希望這是能被搜索引擎發(fā)現(xiàn)的,為了美觀你使用了少見的字體那么你就得用圖片來顯示了:
ExampleSourceCode
這樣當(dāng)然沒錯(cuò),但是有證據(jù)顯示搜索引擎對真實(shí)文本的重視遠(yuǎn)超過alt文本(因?yàn)橐呀?jīng)有太多網(wǎng)站使用alt文本充當(dāng)關(guān)鍵字),因此,我們得用另一種方法:
Buywidgets
,那你的漂亮字體怎么辦呢?下面的CSS可以幫上忙:ExampleSourceCode
- h1{
- background:url(/widget-image.gif)no-repeat;
- }
- h1span{
- position:absolute;
- left:-2000px;
- }
現(xiàn)在你既用上了漂亮的圖片又很好的隱藏了真實(shí)文本——借助CSS,文本被定位于屏幕左側(cè)-2000像素處。
6.CSS盒模型hack的另一選擇
CSS盒模型hack被用來解決IE6之前的瀏覽器顯示問題,IE6.0之前的版本會把某元素的邊框值和填充值包含在寬度之內(nèi)(而不是加在寬度值上)。例如,你可能會使用以下CSS來指定某個(gè)容器的尺寸:
ExampleSourceCode
- #box{
- width:100px;
- border:5px;
- padding:20px;
- }
然后在html中應(yīng)用:
...
盒的總寬度在幾乎所有瀏覽器中為150像素(100像素寬度+兩條5像素的邊框+兩個(gè)20像素的填充),唯獨(dú)在IE6之前版本的瀏覽器中仍然為100像素(邊框值和填充值包含在寬度值中),盒模型的hack正是為了解決這一問題,但是也會帶來麻煩。更簡單的辦法如下:
CSS:
- #box{
- width:150px;
- }
- #boxdiv{
- border:5px;
- padding:20px;
- }
html:
...
這樣一來在任何瀏覽器中盒的總寬度都將是150像素。
7.將塊元素居中
假設(shè)你的網(wǎng)站使用了固定寬度的布局,所有的內(nèi)容置于屏幕中央,可以使用以下的CSS:
ExampleSourceCode
- #content{
- width:700px;
- margin:0auto;
- }
你可以把html的body之內(nèi)任何項(xiàng)目置于中,該項(xiàng)目將自動(dòng)獲得相等的左右邊界值從而保證了居中顯示。不過,這在IE6之前版本的瀏覽器中仍然有問題,將不會居中,因此必須修改如下:
ExampleSourceCode
- body{
- text-align:center;
- }
- #content{
- text-align:left;
- width:700px;
- margin:0auto;
- }
對body的設(shè)定將導(dǎo)致主體內(nèi)容居中,但是連所有的文字也居中了,這恐怕不是你想要的效果,為此#content的div還要指定一個(gè)值:text-align:left。
8.使用CSS實(shí)現(xiàn)垂直居中
垂直居中對表格來說是小菜一碟,只需指定單元格為vertical-align:middle即可,但這在CSS布局中不管用。假設(shè)你將一個(gè)導(dǎo)航菜單的高度設(shè)為2em,然后在CSS中指定垂直對齊的規(guī)則,文字還是會被排到盒的頂部,根本沒有什么區(qū)別。
要解決這一問題,只需將盒的行高設(shè)為與盒的高度相同即可,以這個(gè)例子來說,盒高2em,那么只需在CSS中再加入一條:line-height:2em就可實(shí)現(xiàn)垂直居中了!
9.容器內(nèi)的CSS定位
CSS的最大優(yōu)點(diǎn)之一就是可以將對象定位在文檔的任何位置,同樣的也可以將對象在某容器內(nèi)進(jìn)行定位。只需要為該容器添加一條CSS規(guī)則:
ExampleSourceCode
- #container{
- position:relative;
- }
則容器內(nèi)的任何元素的定位都是相對于該容器的。
如果想將navigation定位在容器內(nèi)離左邊界30像素,離頂部5像素,可以使用以下CSS語句:
ExampleSourceCode
- #navigation{
- position:absolute;
- left:30px;
- top:5px;
- }
10.延伸至屏幕底部的背景色
CSS的缺點(diǎn)之一是缺乏垂直方向的控制,從而導(dǎo)致了一個(gè)表格布局不會遇到的問題。假設(shè)你在頁面的左側(cè)設(shè)定了一列用于放置網(wǎng)站的導(dǎo)航。頁面為白色背景,但你希望導(dǎo)航所在的列為藍(lán)色背景,使用以下CSS即可:
ExampleSourceCode
- #navigation{
- background:blue;
- width:150px;
- }
問題在于導(dǎo)航項(xiàng)不會一直延伸到頁面的底部,自然它的背景色也不會延伸到底部。于是左列的藍(lán)色背景在頁面上被半路截?cái)?,浪費(fèi)了你的一番設(shè)計(jì)。怎么辦呢?很不幸我們現(xiàn)在只能用欺騙的辦法,即將body的背景指定為與左列同顏色同寬度的圖片,CSS如下:
ExampleSourceCode
- body{
- background:url(/blue-image.gif)00repeat-y;
- }
背景圖應(yīng)為寬150像素的藍(lán)色圖片。這一辦法的缺點(diǎn)是沒法使用em來指定左列的寬度,當(dāng)用戶改變文字的大小導(dǎo)致內(nèi)容的寬度擴(kuò)張時(shí),背景色的寬度不會隨之改變。
到寫這篇文章為止這是對這類問題的唯一解決辦法,因此你只能為左列使用像素值來獲得能夠自動(dòng)延伸的不同的背景色。
【編輯推薦】
- 輕松實(shí)現(xiàn)CSS樣式實(shí)時(shí)切換技巧
- SS樣式表文件優(yōu)化五個(gè)小技巧
- CSS2.0中最常用的十八般兵器
- 學(xué)習(xí)筆記 剖析CSS縮寫六大規(guī)則
- 解讀CSS中position屬性四大可選值用法
分享題目:CSS樣式表設(shè)計(jì)十個(gè)雕蟲小技
標(biāo)題鏈接:http://www.dlmjj.cn/article/coshoce.html


咨詢
建站咨詢
