圖片的透明效果是網(wǎng)頁中需要用到的一種特殊形式,雖然不是非常的常用,但是遇到這樣的需求往往有點(diǎn)措手不及,在webjx.com的文章中雖然有這方面的CSS實(shí)例,但還沒有系統(tǒng)的介紹過CSS Alpha透明,我們今天共同學(xué)習(xí)一下相關(guān)的知識。
關(guān)于CSS Alpha透明的相關(guān)知識。先請看如下代碼:
filter:alpha(opacity=50); /* IE */
-moz-opacity:0.5; /* Moz + FF */
opacity: 0.5; /* 支持CSS3的瀏覽器(FF 1.5也支持)*/
簡單解釋,IE使用私有屬性filter:alpha(opacity),Moz Family使用私有屬性-moz-opacity,而標(biāo)準(zhǔn)的屬性是opacity(CSS 3, Moz Family部分支持CSS3)。后面的數(shù)值是透明度,使用百分比或者小數(shù)(alpha(opacity))使用大于0小于100的數(shù)值,其實(shí)也是百分比)。
從上面的代碼中你沒有看到Opera。沒錯,Opera還未支持標(biāo)準(zhǔn)的opacity,也沒有其私有的可支持Alpha透明的屬性。
但是,我們知道,Opera是支持Alpha透明的PNG圖片的(當(dāng)然Moz Family也支持)。所以我們可以使用背景圖片來實(shí)現(xiàn)Alpha透明效果。
關(guān)鍵在于:
background:transparent url(alpha80.png) left top repeat!important;
background:#ccc;
filter:alpha(opacity=50);
既然Moz Family支持Alpha透明的PNG,所以我們沒有必要使用其私有屬性了。當(dāng)然,你可以使用標(biāo)準(zhǔn)的opacity,但別同時使用Alpha透明圖片和opacity,這樣的話就成了兩者的混合了。你可以把上面的例子下載過來,然后/*opacity:.5;*/的注釋看看