一個(gè)css與js結(jié)合的下拉菜單支持主流瀏覽器
首先聲明:
本人雖然在web前端崗位干了好多年,但無奈崗位對(duì)技術(shù)要求不高。html,css用的比較多,JavaScript自己原創(chuàng)的很少,基本都是copy修改,所以自己真正動(dòng)手寫時(shí),發(fā)現(xiàn)基礎(chǔ)很不牢固,邊學(xué)習(xí)邊實(shí)踐,收獲很大。
效果圖:
不廢話了,貼碼了
1、css代碼
a:link{color:white;text-decoration:none;}
a:visited{color:white;text-decorative:none;}
a:hover{color:white;text-decorative:none;}
a:active{color:white;text-decorative:none;}
li{float:left;display:inline;background-color:#003366;width:120px;text-align:center;margin:2px;padding:10px 0 5px 0;position:relative;}
.limouseover{background-color:#0033ff;color:red;}
.limouseout{background-color:#003366;color:black;}
li ul{display:none;width:120px;position:absolute;left:0;top:30px;}
li ul li{margin:0px auto;border-top:1px solid #006699;}
2、JavaScript代碼
<script language=javascript>
function menu(menu1){
//鼠標(biāo)移入移出classname切換和子菜單隱藏、顯示切換。
if (document.getElementById(menu1)){
var menu_ul=document.getElementById(menu1);
if (menu_ul.getElementsByTagName("li").length){
var menu_li=menu_ul.getElementsByTagName("li");
for (i in menu_li){
menu_li[i].onmouseover=function(){this.className="limouseover";if (this.getElementsByTagName("ul").length){this.getElementsByTagName("ul")[0].style.display="block";}}
menu_li[i].onmouseout=function(){this.className="limouseout";if (this.getElementsByTagName("ul").length){this.getElementsByTagName("ul")[0].style.display="none";}}
}
}
}
}
</script>
3、html代碼
<ul id=menu1>
<li><a href="">首頁</a></li>
<li><a href="">菜單1菜單1</a>
<ul>
<li><a href="">子菜單1子菜單1子菜單1子菜單1</a></li>
<li><a href="">子菜單2</a></li>
</ul>
</li>
<li><a href="">菜單2</a>
<ul>
<li><a href="">子菜單1子菜單1子菜單1子菜單1</a></li>
<li><a href="">子菜單2</a></li>
</ul>
</li>
</ul>
<script>var menu1=new menu("menu1");</script>
說明:
1、考慮到ul和li頁面用的比較多,可以在css前加入#menu1,以對(duì)菜單樣式進(jìn)行范圍限制。
2、js主要是對(duì)鼠標(biāo)移入和移除事件進(jìn)行了偵聽,對(duì)應(yīng)切換到limouseover和limouseout樣式;同時(shí)對(duì)子菜單的display屬性進(jìn)行更改,達(dá)到顯示隱藏的功能。
3、同一個(gè)頁面可以重復(fù)調(diào)用,不沖突,html代碼中的JavaScript代碼是調(diào)用實(shí)例,前面的menu1為任意變量名,括號(hào)內(nèi)的menu1為html頁面中的id。
本例的缺點(diǎn):
1、菜單li的mouseover、mouseout和子菜單li的樣式一樣,即同一個(gè)顏色和字體,沒有實(shí)現(xiàn)單獨(dú)設(shè)置。
2、由于要兼容Ie6和ie7,所以其中采用position:absolute的同時(shí),增加了left和top屬性,top要根據(jù)菜單li的整體高度設(shè)定。
相關(guān)文章
JavaScript實(shí)現(xiàn)簡(jiǎn)單日歷效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)單日歷效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09利用函數(shù)的惰性載入提高javascript代碼執(zhí)行效率
在 addEvent 函數(shù)每次調(diào)用的時(shí)候都要走一遍,如果瀏覽器支持其中的一種方法,那么他就會(huì)一直支持了,就沒有必要再進(jìn)行其他分支的檢測(cè)了2014-05-05JavaScript驗(yàn)證18位身份證號(hào)碼最后一位正確性的實(shí)現(xiàn)代碼
這篇文章主要介紹了JavaScript驗(yàn)證18位身份證號(hào)碼最后一位正確性的實(shí)現(xiàn)代碼,小編親測(cè)有效,需要的朋友可以參考下2014-08-08