亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript實戰之帶收放動畫效果的導航菜單

2019-11-20 09:14:20
字體:
來源:轉載
供稿:網友

雖然有很多插件可用,但為了共同提高,我做了一系列JavaScript實戰系列的實例,分享給大家,前輩們若有好的建議,請務必指出,免得誤人子弟??!
今天是第一戰:帶收放動畫效果的菜單,效果如下圖:(樣式有點丑(-^-)) 
( 由于在寫本文時,用的編輯器不同,暫時添加不了演示效果,這里有:最終完整代碼和演示 ) 

動畫效果:鼠標hover改變所有目標的背景和字體顏色,鼠標移動到‘首頁導航',顯示下面的分組菜單,分組菜單有子菜單,點擊可縮放,帶動畫過度效果!而且,可以隨便添加和刪除導航菜單和子菜單,不影響效果! 

如何實現呢? 

第一步:用什么來實現菜單?HTML代碼設計如下,遵循JS代碼和HTML代碼分離的原則!這里你看不到一句JS代碼 

未應用樣式之前是這個樣子的:很古老吧?。。?nbsp;

第二步:CSS樣式。鼠標hover改變所有目標的背景和字體顏色,直接用CSS的transition和:hover,而其他的CSS樣式布局就不全部列舉了,大家自己動手吧,主要注意以下幾點: 

 #ul{ .... z-index: 100; } #ul li{ display: inline-block; position: relative; top: 0; left: -25px; width: 10%; min-width: 70px; height: 30px; text-align: center; line-height: 30px; border: 1px solid gray; border-radius:10px; background-color: aliceblue; cursor: pointer; -webkit-transition: all ease-in-out 0.3s; -moz-transition: all ease-in-out 0.3s; -ms-transition: all ease-in-out 0.3s; -o-transition: all ease-in-out 0.3s; transition: all ease-in-out 0.3s; } #ul li:hover{background-color: aquamarine;color: red;} ... .show-hide:hover{background-color: beige} .a-div{ background-color: aquamarine; border-radius:10px; color: black; display: none; opacity: 0 } .a{ z-index: -1; display: block; ... } 

第三步:這一步是重點。如果給每個菜單選項和分組都添加事件監聽,個人覺得好麻煩,且代碼量肯定多不少,有沒有什么辦法就在一個元素上加監聽就能實現呢?

答案肯定是有的,利用事件的冒泡機制!在父元素ul標簽上添加事件監聽,而在監聽函數里直接改變觸發事件的元素樣式就可以了,就這么簡單!

代碼如下:

var ul = document.getElementById('ul');ul.addEventListener('mouseover',listener1,false);ul.addEventListener('mouseout',listener2,false);ul.addEventListener('click',listener3,false); 
 

 因為IE8及以下版本沒有addEventListener,如果要兼容,還得加attachEvent對應的代碼。

第四:主角登場!實現listener1、listener2、listener3監聽函數。

首先來最簡單的listener1函數,代碼如下:

function listener1(event){ //event = event||window.event; //兼容IE8及以前版本 var target = event.target||event.srcElement; //兼容IE8及以前版本 if(target.tagName.toLowerCase() === 'li'){ var div1 = target.getElementsByTagName('div')[0]; div1.style.display = 'block'; var i = 0; var id; (function foo(){ if(i>=1){clearTimeout(id);id=null;return;} i+=0.2; div1.style.opacity = i; id = setTimeout(function(){clearTimeout(id);foo()},30);      })();   } } 

同樣,一切為了IE8及更舊版本?! ?/p>

1.因為它的event沒有target屬性,只有相對應得srcElement屬性  

2.而這一句event = event||window.event;這里其實是可以省略的,只有當用屬性來設置注冊事件監聽時,如ul.onmouseover = function(){},或<ul onmouseover='func'>,IE8及更舊版本只能通過window.event來取得當前的Event對象

好了,現在獲得了當前觸發事件的target,事情就簡單很多了,通過他就可以改變它自己和它的親戚!

下面是listener2函數,用在mouseout時觸發,主要是操控target的子元素DIV,代碼如下:

function listener2(event){ //event = event||window.event; var target = event.target||event.srcElement; if(target.tagName.toLowerCase() === 'li'){ var div1 = target.getElementsByTagName('div')[0]; div1.onmouseover = function(){ div1.style.display = 'block'; div1.style.opacity = 1; }; div1.onmouseout = function(){ div1.style.display = 'none'; div1.style.opacity = 0; }; div1.style.display = 'none'; //這一組是為了實現當鼠標從上方出去時隱藏div1 div1.style.opacity = 0; } } 

好了,到這里,已經實現了大部分效果了,還有最后一步,那就是1號主角了:listener3函數,它主要負責鼠標點擊時的縮放效果!

實現原理:  

1.函數外面定義一個bool變量當做開關,鼠標點一下開,再點一下關;  

2.通過setTimeout來實現動畫效果,動態的改變子菜單的height和opacity屬性,還有display屬性;

完整代碼如下:

var bool = true; function listener3(event) { var event = event || window.event; var target = event.target || event.srcElement; if (target.className === 'show-hide') { var parent = target.parentElement; var adiv = parent.getElementsByClassName('a-div')[0]; if (window.getComputedStyle(adiv,null).opacity>0.5){bool=false}else{bool=true} var height = 90, changeH, opacity, id; if (bool) { changeH = 0; opacity = 0; target.innerHTML = '財經 -'; (function show() { if (changeH > height) {clearTimeout(id);return} changeH += 5; opacity += 0.06; //console.log('opacity:'+adiv.style.opacity+',height :'+adiv.style.height); adiv.style.height = changeH + 'px'; adiv.style.opacity = opacity; adiv.style.display = 'block'; id = setTimeout(function () {                     clearTimeout(id); show(); }, 16.7); })(); bool = false; } else { changeH = height; opacity = 1; target.innerHTML = '財經 +'; (function hidden() { if (changeH < 0) {clearTimeout(id);adiv.style.display = 'none';return} changeH -= 10; opacity -= 0.11; //console.log('opacity:'+adiv.style.opacity+',height :'+adiv.style.height); adiv.style.height = changeH + 'px'; adiv.style.opacity = opacity; id = setTimeout(function () {                     clearTimeout(id); hidden(); }, 16.7); })(); bool = true; } } }

注意幾點:  

1.記得清除setTimeout的ID,然后退出,否則死循環,如if (changeH < 0) {clearTimeout(id);adiv.style.display = 'none';return}  

2.setTimeout的延遲時間設置為16.7是因為符合屏幕的刷新率60FPS,看著舒服  

3.調試過程中,設置changeH和opacity的遞增遞減值時,記得打印出來,方便調試:

console.log('opacity:'+adiv.style.opacity+',height :'+adiv.style.height);  

4.最后,整個菜單的實現中,最關鍵的是下面這一句,如果沒有這一句,你無法完美實現所有功能,比如:你點開一組子菜單,然后移動到其它組點擊的時候,情況將有很大不同;而window.getComputedStyle用這個的原因是,首次打開時,點任意組的第一下都沒反應,因為直接通過event.target在點第一下時是取不到opacity值的。

if (window.getComputedStyle(adiv,null).opacity>0.5){bool=false}else{bool=true};

不過,IE9以下不支持getComputedStyle方法,IE的Element對象有currentStyle屬性;

如果你對CSS的處理不是很熟悉,看看我的總結:用原生JS讀寫CSS樣式的方法總結

如果你想多了解setTimeout()方法的應用,看看這個:你真的知道setTimeout是如何運行的嗎

對于事件的處理機制,可以看看這個:DOM中的事件處理概覽與原理的全面剖析

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品中文字| 国产精品福利小视频| 成人乱人伦精品视频在线观看| 日本三级韩国三级久久| 欧美丝袜一区二区三区| 亚洲精品一区二区久| 日韩精品中文字幕在线| 国产69精品99久久久久久宅男| 精品中文字幕在线| 国产精品一区av| 日韩免费在线播放| 亚洲美女喷白浆| 日韩精品在线免费播放| 精品亚洲一区二区三区在线观看| 欧美猛男性生活免费| 亚洲精品一区av在线播放| 欧美国产中文字幕| 国产精品视频免费观看www| 亚洲美女中文字幕| 亚洲一二在线观看| 欧美日韩国产中文字幕| 中文字幕亚洲欧美在线| 欧美最猛性xxxxx亚洲精品| 91精品啪aⅴ在线观看国产| 日韩成人在线视频网站| 国产日韩欧美另类| 久久精品在线视频| 国产精品永久免费| 98精品在线视频| 欧美在线国产精品| 尤物九九久久国产精品的特点| 亚洲国产精品悠悠久久琪琪| 亚洲tv在线观看| 日韩免费在线视频| 国产精品福利小视频| 成人亚洲综合色就1024| 亚洲综合视频1区| 福利微拍一区二区| 欧美日韩免费看| 日韩国产精品亚洲а∨天堂免| 欧美日韩国产中字| www.美女亚洲精品| 91久久精品国产| 亚洲肉体裸体xxxx137| 97在线视频免费| 91在线视频成人| 国内精品一区二区三区四区| 欧美性猛交xxxx偷拍洗澡| 91av视频在线播放| 精品久久久久久久久久久久久| 欧美一区第一页| 亚洲国产高潮在线观看| 亚洲欧美国产另类| 精品中文视频在线| 欧美在线免费看| 97成人在线视频| 欧美精品videossex性护士| 国产精品自产拍高潮在线观看| 国产成人97精品免费看片| 欧美电影免费观看网站| 日韩毛片中文字幕| 久久久久久久999精品视频| 国产精品丝袜一区二区三区| 亚洲免费影视第一页| 另类天堂视频在线观看| 国产欧美va欧美va香蕉在线| 人妖精品videosex性欧美| 久久久久久久一区二区三区| 精品无码久久久久久国产| 91在线网站视频| 日韩在线视频观看| www国产亚洲精品久久网站| 国产视频亚洲精品| 久久99视频精品| 日韩av在线电影网| 久久成年人视频| 国产精品夜间视频香蕉| 欧美视频中文字幕在线| 日韩av最新在线| 久久综合九色九九| 亚洲成色777777女色窝| www.欧美精品一二三区| 亚洲欧美一区二区三区四区| 欧美一级片免费在线| 欧美性理论片在线观看片免费| 亚州欧美日韩中文视频| 国产精品一香蕉国产线看观看| 国产精品一区二区av影院萌芽| 九九九久久久久久| 日韩有码在线电影| 3344国产精品免费看| 国产精品入口日韩视频大尺度| 欧美激情综合色综合啪啪五月| 亚洲欧美国产精品专区久久| 欧美性高潮在线| 国内精品久久久久伊人av| 亚洲精品天天看| 亚洲欧美另类人妖| 一本色道久久综合狠狠躁篇怎么玩| 亚洲欧洲免费视频| 欧美国产日产韩国视频| 欧美一区二区三区艳史| 日韩欧美高清视频| 97成人精品视频在线观看| 成人免费在线视频网站| 日韩有码在线观看| 欧美激情a∨在线视频播放| 中文字幕成人在线| 亚洲乱码国产乱码精品精| www欧美xxxx| 日韩av免费观影| 欧美视频专区一二在线观看| 亚洲精品中文字幕av| 欧美一级高清免费| 亚洲老板91色精品久久| 91精品国产91久久久久久| 国产精品69精品一区二区三区| 亚洲人高潮女人毛茸茸| 国产97在线|亚洲| 欧美俄罗斯乱妇| 久久久爽爽爽美女图片| 亚洲激情自拍图| 成人久久一区二区三区| 国产专区欧美专区| 国产精品男人爽免费视频1| 在线视频亚洲欧美| 欧美成人精品影院| 久久久久女教师免费一区| 91国产高清在线| 5278欧美一区二区三区| 91日本在线视频| 国产精品久久久久影院日本| 中文字幕av一区二区三区谷原希美| 欧美中文字幕在线播放| 欧美裸体男粗大视频在线观看| 国产精品主播视频| 丁香五六月婷婷久久激情| 国产91久久婷婷一区二区| 8x拔播拔播x8国产精品| 韩日欧美一区二区| 日韩专区在线观看| 亚洲精品成人av| 欧美限制级电影在线观看| 成人伊人精品色xxxx视频| 日韩专区中文字幕| 欧美日韩中文字幕日韩欧美| 国产精品久久在线观看| 97在线免费观看视频| 91在线观看欧美日韩| 日韩一区二区在线视频| xvideos成人免费中文版| 国产精品一区二区久久精品| 欧美视频第一页| 欧美性在线视频| 3344国产精品免费看| 久久综合五月天| 成人免费淫片视频软件| 久久天天躁夜夜躁狠狠躁2022| 国产91精品黑色丝袜高跟鞋| 久久综合亚洲社区| 国产精品视频色| 色999日韩欧美国产| 久久人人爽人人爽人人片av高清| 91免费精品国偷自产在线|