報(bào)道公司事件 · 傳播行業(yè)動(dòng)態(tài)
很多網(wǎng)站建設(shè)高手都知使用css縮寫(xiě),因?yàn)槭褂每s寫(xiě)可以幫助減少你CSS文件的大小,更加容易閱讀。這里就著重總結(jié)了一些css常用技巧,為網(wǎng)站重構(gòu)打下基礎(chǔ)。
1. Block和inline元素對(duì)比
所有的HTML元素都屬于block和inline之一。
block元素的特點(diǎn)是:
總是在新行上開(kāi)始;
高度,行高以及頂和底邊距都可控制;
寬度缺省是它的容器的100%,除非設(shè)定一個(gè)度 和
是塊元素的例子。
相反地,inline元素的特點(diǎn)是:
和其他元素都在一行上;
高,行高及頂和底邊距不可改變;
寬度就是它的文字或圖片的寬度,不可改變。
, 和是inline元素的例子。
用display: inline 或display: block命令就可以改變一個(gè)元素的這一特性。什么時(shí)候需要改變這一屬性呢?
讓一個(gè)inline元素從新行開(kāi)始;
讓塊元素和其他元素保持在一行上;
控制inline元素的寬度(對(duì)導(dǎo)航條非凡有用);
控制inline元素的高度;
無(wú)須設(shè)定寬度即可為一個(gè)塊元素設(shè)定與文字同寬的背景色。
2. 再來(lái)一個(gè)box黑客方法
之所以有這么多box黑客方法,是因?yàn)镮E在6之前對(duì)box的理解跟別人都不一樣,它的寬度要包含邊線(xiàn)寬和空白。要想讓IE5等同其他瀏覽器保持一致,可以用CSS的方法:
padding: 2em;
border: 1em solid green;
width: 20em;
width/**/:/**/ 14em;
第一個(gè)寬度所有瀏覽器都認(rèn)得,但I(xiàn)E5.x不認(rèn)得第2行的寬度設(shè)置,只因?yàn)槟且恍猩嫌锌瞻椎淖⑨尫?hào)(多么蠢的語(yǔ)法分析!),所以IE5.x就用20減掉一些空白,而其他瀏覽器會(huì)用14這個(gè)寬度,因?yàn)樗堑?行,會(huì)覆蓋掉第1行。
3. 頁(yè)面的最小寬度
min-width是個(gè)非常方便的CSS命令,它可以指定元素最小也不能小于某個(gè)寬度,這樣就能保證排版一直正確。但I(xiàn)E不認(rèn)得這個(gè),而它實(shí)際上把width當(dāng)做最小寬度來(lái)使。為了讓這一命令在IE上也能用,可以把一個(gè)
放到 標(biāo)簽下,然后為div指定一個(gè)類(lèi):
然后CSS這樣設(shè)計(jì):
#container
{
min-width: 600px;
width:expression(document.body.clientWidth < 600? "600px": "auto" );
}
第一個(gè)min-width是正常的;但第2行的width使用了Javascript,這只有IE才認(rèn)得,這也會(huì)讓你的HTML文檔不太正規(guī)。它實(shí)際上通過(guò)Javascript的判定來(lái)實(shí)現(xiàn)最小寬度。
同樣的辦法也可以為IE實(shí)現(xiàn)最大寬度:
#container
{
min-width: 600px;
max-width: 1200px;
width:expression(document.body.clientWidth < 600? "600px" : document.body.clientWidth > 1200? ”1200px“ : ”auto";
}
4. IE與寬度和高度的問(wèn)題
IE不認(rèn)得min-這個(gè)定義,但實(shí)際上它把正常的width和height當(dāng)作有min的情況來(lái)使。這樣問(wèn)題就大了,假如只用寬度和高度,正常的瀏覽器里這兩個(gè)值就不會(huì)變,假如只用min-width和min-height的話(huà),IE下面根本等于沒(méi)有設(shè)置寬度和高度。
5. 區(qū)分大小寫(xiě)
當(dāng)在XHTML中使用CSS,CSS里定義的元素名稱(chēng)是區(qū)分大小寫(xiě)的。為了避免這種錯(cuò)誤,我建議所有的定義名稱(chēng)都采用小寫(xiě)。
class和id的值在HTML和XHTML中也是區(qū)分大小寫(xiě)的,如果你一定要大小寫(xiě)混合寫(xiě),請(qǐng)仔細(xì)確認(rèn)你在CSS的定義和XHTML里的標(biāo)簽是一致的。
6. 取消class和id前的元素限定
當(dāng)你寫(xiě)給一個(gè)元素定義class或者id,你可以省略前面的元素限定,因?yàn)镮D在一個(gè)頁(yè)面里是唯一的,clas s可以在頁(yè)面中多次使用。你限定某個(gè)元素毫無(wú)意義。
Copyright 大連網(wǎng)龍科技 版權(quán)所有 遼ICP備14006349號(hào) html - txt - xml