国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > JS > 正文

javascript與CSS復(fù)習(xí)(二)

2024-09-06 12:45:32
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友
visibility:在切換元素可見(jiàn)性的同時(shí)會(huì)保持元素在普通流中的位置和空間。它有兩個(gè)值:visible(默認(rèn)的)和hidden(不可見(jiàn)的),
例如:
代碼如下: <p>Hello <b>John</b>, how are you today?</p>
瀏覽器中是:Hello John, how are you today? 接著我們把John所在b的visibility設(shè)置為hidden后,就會(huì)變成這樣
Hello , how are you today?
display:為我們控制元素的布局提供了更豐富的選擇。可以是inline、block或是none(它完全從文檔中隱藏了元素,結(jié)果跟從文檔中刪除了該元素的情形看起來(lái)一樣)。還是上面的例子,如果我們用了display:none。那么結(jié)果是
Hello , how are you today?
下面給出書(shū)中兩個(gè)簡(jiǎn)單函數(shù)用于顯示和隱藏元素
代碼如下://使用display隱藏元素
function hide(elem) {
//找出元素display的當(dāng)前狀態(tài)
var curDisplay = getStyle(elem, 'display');
//記錄它的display狀態(tài)
if(curDisplay != 'none')
elem.$oldDisplay = curDisplay;
//設(shè)置display為none
elem.style.display = 'none';
}
//使用display顯示元素
function show(elem) {
//設(shè)置display屬性為它的原始值
elem.style.display = elem.$oldDisplay || ' ';
}

接下來(lái)我們來(lái)研究下透明度opacity,這可以給元素添加一個(gè)很cool的效果...看下下面這個(gè)設(shè)置元素透明度的函數(shù)。
代碼如下://設(shè)置元素的透明度(級(jí)別從0-100)
function setOpacity(elem, level) {
//如果存在filters這個(gè)屬性,則它是IE
if(elem.filters) {
elem.style.filters = 'alpha(opacity=' + level + ')';
} else { //否則,使用W3C的opacity屬性
elem.style.opacity = level / 100;
}
}

有了這些調(diào)整元素位置、尺寸和可見(jiàn)性的方法,我們就能把它們結(jié)合起來(lái)創(chuàng)建動(dòng)畫(huà)。
代碼如下:function slideDown(elem) {
//從0高度開(kāi)始滑動(dòng)
elem.style.height = '0px';
//先顯示元素(但是看不到它,因?yàn)樗母叨葹?)
show(elem);
//找到元素的完整的潛在高度
var h = fullHeight(elem);
//我們?cè)?秒鐘內(nèi)執(zhí)行一個(gè)20幀的動(dòng)畫(huà)
for(var i = 0; i <= 100; i += 5) {
//保證我們能夠保持正確的'i'的閉包函數(shù)
(function() {
var pos = i;
//設(shè)置timeout以讓它能在指定的時(shí)間點(diǎn)運(yùn)動(dòng)
setTimeout(function() {
//設(shè)置元素新的高度
elem.style.height = (pos / 100) * h + 'px';
}, (pos + 1) * 10);
})();
}
}

這里有個(gè)閉包的概念,理解起來(lái)可能有些難度,感興趣深入的園友可以去Google下,這里就不多討論了。
接下來(lái)用setOpacity函數(shù)寫(xiě)個(gè)"漸顯"函數(shù):
代碼如下:function fadeIn(elem) {
//從0透明度開(kāi)始
setOpacity(elem, 0);
//先顯示元素(但是看不到它,因?yàn)樗耐该鞫仁?)
show(elem);
//我們?cè)?秒鐘內(nèi)執(zhí)行一個(gè)20幀的動(dòng)畫(huà)
for(var i = 0; i < 100; i += 5) {
//保證我們能夠保持正確的'i'的閉包函數(shù)
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 民权县| 钟山县| 石棉县| 桃园市| 唐山市| 两当县| 宽甸| 博湖县| 东光县| 临安市| 昌邑市| 乌兰浩特市| 洪泽县| 抚顺县| 黄石市| 宣汉县| 视频| 襄垣县| 澎湖县| 龙南县| 惠来县| 来凤县| 淅川县| 德惠市| 塔河县| 丰城市| 浦江县| 招远市| 巫溪县| 萍乡市| 松溪县| 镶黄旗| 隆德县| 鹤岗市| 日土县| 高密市| 浏阳市| 黄山市| 平凉市| 英山县| 三门峡市|