天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

javascript與CSS復習(二)

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

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

有了這些調整元素位置、尺寸和可見性的方法,我們就能把它們結合起來創建動畫。
復制代碼 代碼如下:function slideDown(elem) {
//從0高度開始滑動
elem.style.height = '0px';
//先顯示元素(但是看不到它,因為它的高度為0)
show(elem);
//找到元素的完整的潛在高度
var h = fullHeight(elem);
//我們在1秒鐘內執行一個20幀的動畫
for(var i = 0; i <= 100; i += 5) {
//保證我們能夠保持正確的'i'的閉包函數
(function() {
var pos = i;
//設置timeout以讓它能在指定的時間點運動
setTimeout(function() {
//設置元素新的高度
elem.style.height = (pos / 100) * h + 'px';
}, (pos + 1) * 10);
})();
}
}

這里有個閉包的概念,理解起來可能有些難度,感興趣深入的園友可以去Google下,這里就不多討論了。
接下來用setOpacity函數寫個"漸顯"函數:
復制代碼 代碼如下:function fadeIn(elem) {
//從0透明度開始
setOpacity(elem, 0);
//先顯示元素(但是看不到它,因為它的透明度是0)
show(elem);
//我們在1秒鐘內執行一個20幀的動畫
for(var i = 0; i < 100; i += 5) {
//保證我們能夠保持正確的'i'的閉包函數
(function(){
var pos = i;
//設置timeout以讓它能在指定的事件內運行
setTimeout(function() {
setOpacity(elem, pos);
}, (pos + 1) * 10);
})();
}
}

為了代碼的正確性,我寫完后都去測試一下,因為發現書中會有些小錯誤,剛測試完上面的slideDown方法,應該把var h = fullHeight(elem);放到函數內容的第一句,不然沒效果....
第二部分的復習就到這里,慢慢消化,學東西可不能急于求成哦。

JavaScript技術javascript與CSS復習(二),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: sao虎影院桃红视频在线观看 | 女仆乖H调教跪趴 | 久久亚洲午夜牛牛影视 | 久久毛片免费看一区二区三区 | 国产亚洲999精品AA片在线爽 | a一级一片免费观看视频 | 久久久久久电影 | 中文字幕s级优女区 | 暖暖的视频完整视频免费韩国 | 超碰97超碰在线视频哦 | 男女啪啪抽搐呻吟高潮动态图 | 久久亚洲成a人片 | 精品无码无人网站免费视频 | 亚洲中文字幕在线精品 | 最好看中文字幕国语 | 人人碰国产免费线观看 | 97人妻AV天天澡夜夜爽 | 亚洲精品免费观看 | 天堂Av亚洲欧美日韩国产综合 | 扒开双腿疯进出爽爽爽动态图 | 色多多污版app下载网站 | 免费伦理片网站 | 亚洲欧美国产视频 | 欧美激情视频一区二区 | 国产在线视频一区二区不卡 | 国产精品久久久久久免费字体 | 精品人妻伦一二三区久久AAA片 | 国产乱人偷精品视频A人人澡 | 全彩无翼污之邪恶女教师 | 成人伊人青草久久综合网 | 6080yy奇领电影在线看 | jlzz中国jizz日本老师水多 | 免费特黄一区二区三区视频一 | 久久精品AV一区二区无码 | 在线视频中文字幕 | 污到湿的爽文免费阅读 | 免费高清毛片 | 口内射精颜射极品合集 | 偷柏自拍亚洲综合在线 | 国产人妻人伦精品836700 | 夫外出被公侵犯日本电影 |