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

首頁 > 編程 > JavaScript > 正文

JavaScript實戰之菜單特效

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

本文將持續添加我自己用原生JS寫的各種菜單特效,雖然網上一搜一大堆,但我還是喜歡自己來寫一寫!
 這是上一篇:JavaScript實戰(帶收放動畫效果的導航菜單)
下面是經過優化后的完整代碼,優化了CSS樣式、簡化事件函數、減少HTML層級,刪了至少20行以上的冗余代碼 

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title></title> <script> window.onload = function() { //========伸縮動畫菜單 var ul = document.getElementById('ul'); if(ul.addEventListener){ ul.addEventListener('mouseover',listener1,true); ul.addEventListener('mouseout',listener2,true); ul.addEventListener('click',listener3,false); }else if(ul.attachEvent){ //兼容IE8及以前版本 ul.attachEvent('onmouseover',listener1,false); ul.attachEvent('onmouseout',listener2,false); ul.attachEvent('onclick',listener3,false); } 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';  div1.style.opacity = 1; } } 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.style.display = 'none';  div1.style.opacity = 0;  div1.onmouseover = function(){  div1.style.display = 'block';  div1.style.opacity = 1;  };  div1.onmouseout = function(){  div1.style.display = 'none';  div1.style.opacity = 0;  }; } } var bool = true; function listener3(event) { var event = event || window.event; var target = event.target || event.srcElement; if (target.className === 'show-hide') {  var adiv = target.nextElementSibling;  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;  var text = target.innerHTML.slice(0,-1);  target.innerHTML = text+' -';  (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;  var text = target.innerHTML.slice(0,-1);  target.innerHTML = text+' +';  (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;  } } } }; </script> <style> *{ margin: 0; padding: 0; } a,img{border:0;} ul{ position: absolute; top: 20px; left: 30px; z-index: 100; } #ul li{ display: inline-block; position: relative; height: 30px; text-align: center; line-height: 30px; padding: 3px; border: 1px solid gray; border-radius: 10px 10px 0 0; 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;} .nav-div{ position: absolute; width: 100%; left: -1px; top: 37px; display: none; border: 1px solid gray; border-top: 0; border-radius:0 0 10px 10px; background-color: aliceblue; } .show-hide{ position: relative; display: block; border-radius:0 0 10px 10px; background-color: lightblue; -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; border-bottom: 1px solid gray; } .show-hide:hover{background-color: lavender} .a-div{ background-color: aliceblue; display: none; border-radius:0 0 10px 10px; opacity: 0} .a{ z-index: -1; display: block; text-decoration: none; border-radius:10px; -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; } .a:hover{background-color: lavender} </style></head><body><ul id="ul"> <li>JavaScript實戰 <div class="nav-div"> <span class="show-hide">導航特效 +</span> <div class="a-div"> <a class="a" href="">可收放子菜單</a> <a class="a" href="">切換頁面</a> <a class="a" href="">持續添加中...</a> </div> <span class="show-hide">其它特效 +</span> <div class="a-div"> <a class="a" href="">持續添加中...</a> <a class="a" href="">持續添加中...</a> <a class="a" href="">持續添加中...</a> </div> </div> </li> <li>JavaScript性能優化 <div class="nav-div"> <span class="show-hide">財經 +</span> <div class="a-div"> <a class="a" href="">今日頭條</a> <a class="a" href="">所有新聞</a> <a class="a" href="">往日回看</a> </div> <span class="show-hide">科技 +</span> <div class="a-div"> <a class="a" href="">今日頭條</a> <a class="a" href="">所有新聞</a> <a class="a" href="">往日回看</a> </div> </div> </li> <li>今日新聞 <div class="nav-div"> <span class="show-hide">財經 +</span> <div class="a-div"> <a class="a" href="">今日頭條</a> <a class="a" href="">所有新聞</a> <a class="a" href="">往日回看</a> </div> <span class="show-hide">科技 +</span> <div class="a-div"> <a class="a" href="">今日頭條</a> <a class="a" href="">所有新聞</a> <a class="a" href="">往日回看</a> </div> </div> </li></ul></body></html>

效果圖:

下面是第二個特效:(具體實現比第一個簡單很多,主要注意CSS布局)

<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title></title> <style> *{  margin: 0;  padding: 0; } a,img{border:0;} #menu{  position: absolute;  top: 30px;  left: 0;  right: 0;  margin: auto;  width: 400px;  border-left: 1px solid gray;  border-top: 1px solid gray;  background-color: lemonchiffon;  text-align: center; } #menu li{  list-style: none;  float: left;  width: 99px;  height: 30px;  line-height: 30px;  border-right: 1px solid gray;  background-color: burlywood;  color: white;  -webkit-transition: all ease-in-out 0.5s;  -moz-transition: all ease-in-out 0.5s;  -ms-transition: all ease-in-out 0.5s;  -o-transition: all ease-in-out 0.5s;  transition: all ease-in-out 0.5s; } #menu li:hover{  background-color: lemonchiffon;  color: #336699; } .contain{  position: absolute;  left: -1px;  display: none;  width: 399px;  height: 300px;  color: #336699;  border-left: 1px solid gray;  border-right: 1px solid gray;  border-bottom: 1px solid gray;  background-color: lemonchiffon; } </style> <script> window.onload = function(){  var menu = document.getElementById('menu');  if(menu.addEventListener){  menu.addEventListener('mouseover',show,false);  menu.addEventListener('mouseout',hide,false);  }else if(menu.attachEvent){  menu.attachEvent('onmouseover',show,false);  menu.attachEvent('onmouseout',hide,false);  }  function show(event){  var target = event.target||event.srcElement;  if(target.tagName.toLowerCase() === 'li'){   target.firstElementChild.style.display = 'block';  }else if(target.parentNode.tagName.toLowerCase() === 'li'){   target.style.display = 'block';  }  }  function hide(event){  var target = event.target||event.srcElement;  if(target.tagName.toLowerCase() === 'li'){   target.firstElementChild.style.display = 'none';  }else if(target.parentNode.tagName.toLowerCase() === 'li'){   target.style.display = 'none';  }  } } </script></head><body><div id="menu"> <ul> <li id="menu1">蘇福的特效1  <div class="contain">111111111111</div> </li> <li id="menu2">蘇福的特效2  <div class="contain">222222222222</div> </li> <li id="menu3">蘇福的特效3  <div class="contain">333333333333</div> </li> <li id="menu4">蘇福的特效4  <div class="contain">444444444444</div> </li> </ul></div></body></html>

效果圖:

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91免费福利视频| 亚洲精品动漫100p| 国产精品免费久久久| 国产日产久久高清欧美一区| 日韩免费观看在线观看| 亚洲人精选亚洲人成在线| 国产精品678| 日韩免费视频在线观看| 亚洲欧洲av一区二区| 欧美天天综合色影久久精品| 国产亚洲成精品久久| 国产99久久精品一区二区 夜夜躁日日躁| 久久久久久久久久久91| 欧美一区二粉嫩精品国产一线天| 国产丝袜高跟一区| 国产精品专区一| 国产精品久久久| 欧美视频中文在线看| 日韩欧美成人免费视频| 国产精品免费观看在线| 欧美色视频日本高清在线观看| 国产精品自产拍在线观看中文| 中文字幕日韩有码| 国模精品视频一区二区| 国产一区二区黄| 亚洲成人中文字幕| 亚洲国产精品系列| 91影视免费在线观看| 久久99国产精品久久久久久久久| 91社区国产高清| 在线观看精品国产视频| 色噜噜狠狠狠综合曰曰曰88av| 欧美亚洲成人网| 国产日韩欧美91| 欧美成人午夜激情视频| 欧美激情啊啊啊| 日本久久久久久久| 欧美性受xxxx白人性爽| 国产成人福利视频| 成人免费网站在线看| 欧美激情在线视频二区| 日韩av电影中文字幕| 亚洲欧美一区二区三区情侣bbw| 国产成人97精品免费看片| 成人黄色激情网| 欧美成人在线影院| 一区二区三区黄色| 美女国内精品自产拍在线播放| 性欧美亚洲xxxx乳在线观看| 欧美一级片久久久久久久| 国产一区二区视频在线观看| 久久久久久久久国产精品| 精品久久久久久| 亚洲性xxxx| 国产精品中文久久久久久久| 国产日韩欧美一二三区| 一个人www欧美| 中文字幕视频在线免费欧美日韩综合在线看| 日韩视频在线一区| 98精品在线视频| y97精品国产97久久久久久| 亚洲毛片在线看| 7777免费精品视频| 国产69精品99久久久久久宅男| 91久久国产综合久久91精品网站| 欧美—级a级欧美特级ar全黄| 91久久精品视频| 国产v综合v亚洲欧美久久| 国产精品手机播放| 日韩视频在线免费| 成人综合国产精品| 久久久亚洲福利精品午夜| 亚洲天堂第二页| 国产精品久久不能| 欧美激情中文字幕乱码免费| 久久五月天综合| 国产精品视频xxxx| 久久九九亚洲综合| 日韩免费在线看| 欧美精品国产精品日韩精品| 欧美性高潮床叫视频| 国内精品久久久| 亚洲自拍高清视频网站| 国产精品久久久久久久app| 日韩精品在线观| 久久69精品久久久久久久电影好| 成人h视频在线| 国产精品久久网| 欧洲成人性视频| 国内精品伊人久久| 国产精品第七十二页| 久久久免费电影| 亚洲黄色在线观看| 久久精品国产一区| 久久免费视频网站| 成人h片在线播放免费网站| 1769国内精品视频在线播放| 久久在线视频在线| 欧美激情中文字幕乱码免费| 91网在线免费观看| 国产精品专区h在线观看| 中文字幕日韩av电影| 欧美视频不卡中文| 91在线视频一区| 国产精品91久久久| 91国内产香蕉| 国产精品爽爽ⅴa在线观看| 欧美激情在线有限公司| 最新国产精品拍自在线播放| 久久夜色精品国产亚洲aⅴ| 全亚洲最色的网站在线观看| 国产免费一区二区三区在线观看| 欧美成在线视频| 91久久国产精品91久久性色| 午夜精品一区二区三区视频免费看| 91日本在线视频| 欧美午夜www高清视频| 国产一区二区动漫| 91色琪琪电影亚洲精品久久| 亚洲美女性生活视频| 亚洲白虎美女被爆操| 国产精品私拍pans大尺度在线| 91av视频导航| 久久精品视频在线观看| 日本高清视频一区| 亚洲第一av网| 欧美自拍视频在线观看| 欧美激情a∨在线视频播放| 亚洲午夜精品久久久久久久久久久久| 亚洲精品国产品国语在线| 国产精品尤物福利片在线观看| 日本亚洲欧美三级| 欧美电影免费观看高清完整| 亚洲欧美一区二区三区在线| 欧美午夜精品久久久久久人妖| 亚洲精品狠狠操| 色婷婷综合久久久久中文字幕1| 精品视频—区二区三区免费| 成人免费激情视频| 欧美日韩国产黄| 亚洲图中文字幕| 在线电影中文日韩| 亚洲欧美日韩精品| 韩国欧美亚洲国产| 久久精品久久精品亚洲人| 57pao成人国产永久免费| 成人做爽爽免费视频| 色综合久久88色综合天天看泰| 性日韩欧美在线视频| 国产一区二区三区高清在线观看| 日韩**中文字幕毛片| 国产日韩视频在线观看| 国产网站欧美日韩免费精品在线观看| 亚洲aⅴ日韩av电影在线观看| 在线性视频日韩欧美| 成人网址在线观看| 精品久久久在线观看| 国产脚交av在线一区二区| 日韩在线观看免费av| 亚洲成成品网站| 亚洲国产成人久久综合| 97精品伊人久久久大香线蕉| 韩国19禁主播vip福利视频| 国产精品第10页|