JavaScript實(shí)現(xiàn)HTML導(dǎo)航欄下拉菜單
JavaScript實(shí)現(xiàn)HTML導(dǎo)航欄下拉菜單[懸浮顯示]
前端界面進(jìn)行設(shè)計(jì)時(shí),我們會(huì)遇到鼠標(biāo)懸浮在某選項(xiàng)上,然后就會(huì)憑空顯示出菜單出來(lái),這種設(shè)計(jì)的確受到了很多人的青睞。其實(shí)純css也是可以實(shí)現(xiàn)的,但是會(huì)有一些限制,必須如要顯示的菜單需要作為鼠標(biāo)懸浮元素的子元素,選擇器優(yōu)先級(jí)等等。廢話不多說(shuō),直接看效果!

樣式有點(diǎn)丑。
代碼實(shí)現(xiàn)(JavaScript)
1、獲取要懸浮的對(duì)象和菜單對(duì)象
//獲取需要懸浮的對(duì)象
let show = document.getElementById("show");
//獲取被隱藏的菜單
let menu = document.getElementById("menu");
2、對(duì)懸浮對(duì)象添加鼠標(biāo)懸浮事件
//給show添加鼠標(biāo)懸浮事件
show.onmouseover = function(){
//改變菜單的內(nèi)聯(lián)樣式display為block,菜單顯示
menu.style.display = "block";
}
3、對(duì)懸浮對(duì)象添加鼠標(biāo)離開事件
如果先觸發(fā)了懸浮對(duì)象show的鼠標(biāo)懸浮事件,不移動(dòng)到菜單menu上就鼠標(biāo)就離開了,會(huì)出現(xiàn)菜單無(wú)法隱藏的bug!所以在懸浮對(duì)象的鼠標(biāo)離開事件中,我們需要進(jìn)行判斷,如果鼠標(biāo)移開后的位置不在菜單menu的范圍內(nèi),則令菜單menu隱藏,否則就繼續(xù)顯示
show.onmouseout = function(){
//獲取菜單欄的坐標(biāo)值
let menux = menu.offsetLeft;
let menuy = menu.offsetTop;
let menuX = menu.offsetLeft+menu.offsetWidth;
let menuY = menu.offsetTop+menu.offsetHeight;
//獲取鼠標(biāo)的坐標(biāo)值
let event = window.event;
let mouseX = event.clientX;
let mouseY = event.clientY;
if(mouseX<menux || mouseX>menuX || mouseY<menuY || mouseY>menuY){
menu.style.display = "none";
}
}
4、分別給菜單menu添加鼠標(biāo)懸浮和離開事件
這里見(jiàn)碼之意,假如鼠標(biāo)在menu上就顯示,離開了就隱藏
//分別給menu對(duì)象綁定鼠標(biāo)懸浮和鼠標(biāo)離開事件
menu.onmouseover = function(){
menu.style.display = "block";
}
menu.onmouseleave = function(){
menu.style.display = "none";
}
源代碼:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script>
window.onload = function(){
//獲取需要懸浮的對(duì)象
let show = document.getElementById("show");
//獲取被隱藏的菜單
let menu = document.getElementById("menu");
//給show添加鼠標(biāo)懸浮事件
show.onmouseover = function(){
//改變菜單的內(nèi)聯(lián)樣式display為block
menu.style.display = "block";
}
//
show.onmouseout = function(){
//獲取菜單欄的坐標(biāo)值
let menux = menu.offsetLeft;
let menuy = menu.offsetTop;
let menuX = menu.offsetLeft+menu.offsetWidth;
let menuY = menu.offsetTop+menu.offsetHeight;
//獲取鼠標(biāo)的坐標(biāo)值
let event = window.event;
let mouseX = event.clientX;
let mouseY = event.clientY;
if(mouseX<menux || mouseX>menuX || mouseY<menuY || mouseY>menuY){
menu.style.display = "none";
}
}
//分別給menu對(duì)象綁定鼠標(biāo)懸浮和鼠標(biāo)離開事件
menu.onmouseover = function(){
menu.style.display = "block";
}
menu.onmouseleave = function(){
menu.style.display = "none";
}
}
</script>
<style>
*{
margin: 0;
padding: 0;
}
li{
list-style: none;
}
#show {
margin-top: 10px;
margin-left: 10px;
width: 50px;
height: 30px;
border: 1px solid #ccc;
background-color: pink;
}
#menu{
display: none;
margin-left: 10px;
width: 50px;
border: 1px solid #ccc;
background: rgba(0, 0, 0, 0.6);
}
#menu a{
color: #fff;
text-decoration: none;
}
</style>
</head>
<body>
<div id="box">
<div id="show"><a href="#">Gorho</a></div>
<ul id="menu">
<li><a href="#">選項(xiàng)一</a></li>
<li><a href="#">選項(xiàng)二</a></li>
<li><a href="#">選項(xiàng)三</a></li>
</ul>
</div>
</body>
</html>
寫在最后:其實(shí)在作品中需要將菜單menu設(shè)置成絕對(duì)定位,即position:absolute。否則菜單出現(xiàn)后會(huì)擠壓其他盒子的位置,但筆者趕時(shí)間,就沒(méi)有設(shè)置,其實(shí)設(shè)置也很簡(jiǎn)單,在css中加上就大功告成了!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript實(shí)現(xiàn)網(wǎng)頁(yè)下拉菜單效果
- Vue.js下拉菜單組件使用方法詳解
- js 下拉菜單點(diǎn)擊旁邊收起實(shí)現(xiàn)(踩坑記)
- 淺談Vue.js中如何實(shí)現(xiàn)自定義下拉菜單指令
- js實(shí)現(xiàn)按鈕開關(guān)單機(jī)下拉菜單效果
- js動(dòng)態(tài)設(shè)置select下拉菜單的默認(rèn)選中項(xiàng)實(shí)例
- 純JS實(shí)現(xiàn)出生日期[年月日]下拉菜單效果
- JS實(shí)現(xiàn)點(diǎn)擊下拉菜單把選擇的內(nèi)容同步到input輸入框內(nèi)的實(shí)例
- js阻止默認(rèn)右鍵的下拉菜單方法
- js面向?qū)ο蠓庋b級(jí)聯(lián)下拉菜單列表的實(shí)現(xiàn)步驟
相關(guān)文章
什么是cookie?js手動(dòng)創(chuàng)建和存儲(chǔ)cookie
cookie 是存儲(chǔ)于訪問(wèn)者的計(jì)算機(jī)中的變量,在這個(gè)例子中我們要?jiǎng)?chuàng)建一個(gè)存儲(chǔ)訪問(wèn)者名字的 cookie,需要的朋友可以參考下2014-05-05
讓插入到 innerHTML 中的 script 跑起來(lái)的代碼
讓插入到 innerHTML 中的 script 跑起來(lái)的代碼...2007-11-11
解析從小程序開發(fā)者工具源碼看原理實(shí)現(xiàn)
小程序的架構(gòu)設(shè)計(jì)與web技術(shù)還是有一定的差別,其吸取了web技術(shù)的一些優(yōu)勢(shì),同時(shí)也摒棄web技術(shù)中體驗(yàn)等不好的地方。下面通過(guò)問(wèn)題的形式來(lái)說(shuō)說(shuō)小程序架構(gòu)中的一些設(shè)計(jì)點(diǎn)2021-06-06
JavaScript判斷textarea值是否為空并給出相應(yīng)提示
假如用戶沒(méi)有輸入數(shù)據(jù)則給出相應(yīng)提示,那么該如何來(lái)判斷呢?下面以判斷textarea值是否為空為例2014-09-09
js實(shí)現(xiàn)移動(dòng)端導(dǎo)航點(diǎn)擊自動(dòng)滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)移動(dòng)端導(dǎo)航點(diǎn)擊自動(dòng)滑動(dòng)效果,導(dǎo)航可左右滑動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
js實(shí)現(xiàn)的全國(guó)省市二級(jí)聯(lián)動(dòng)下拉選擇菜單完整實(shí)例
這篇文章主要介紹了js實(shí)現(xiàn)的全國(guó)省市二級(jí)聯(lián)動(dòng)下拉選擇菜單,以一個(gè)完整實(shí)例形式較為詳細(xì)的分析了javascript實(shí)現(xiàn)省市二級(jí)聯(lián)動(dòng)下拉菜單的實(shí)現(xiàn)技巧,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-08-08
JS實(shí)現(xiàn)的自定義水平滾動(dòng)字體插件完整實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)的自定義水平滾動(dòng)字體插件,以完整實(shí)例形式分析了javascript自定義水平滾動(dòng)字體插件的定義、原理與使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06
關(guān)于ES6中的箭頭函數(shù)超詳細(xì)梳理
箭頭函數(shù)可以說(shuō)是es6的一大亮點(diǎn),使用箭頭函數(shù),可以簡(jiǎn)化編碼過(guò)程,是代碼更加的簡(jiǎn)潔,下面這篇文章主要給大家介紹了關(guān)于ES6中箭頭函數(shù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08

