原生JS實(shí)現(xiàn)懸停下拉菜單
JS實(shí)現(xiàn)懸停下拉菜單,這個(gè)是前端面試中遇到的場景題,原理就是修改菜單樣式的display屬性的屬性值從none=>block,具體實(shí)現(xiàn)見下,重點(diǎn)關(guān)注下面幾個(gè)部分。
- 給每個(gè)section設(shè)置浮動(dòng)。
- 將可繼承屬性設(shè)置在section父盒子上,字體相關(guān)的屬性。
- 設(shè)置懸停時(shí),懸停在section父盒子上,子元素head背景改變;也可以直接懸停在head類,寫作`.head:hover`。但是會(huì)出現(xiàn)一個(gè)問題就是當(dāng)鼠標(biāo)懸停在li上的時(shí)候head會(huì)變回最初的樣子,因此推薦將hover放在section上。
- 但是menu展示只能懸停在父盒子section上,因?yàn)楸旧聿徽故荆ú荒軕彝T趆ead上,head不是父盒子)。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>懸停下拉菜單</title> <style> /* 通配符、a、li必要的去除既有樣式 */ * { margin: 0; padding: 0; } a { text-decoration: none; color: black; } /* li在這里只去掉既有樣式 不規(guī)定寬度 */ li { list-style: none; } /* flex布局每個(gè)作為item的section */ .container { margin: 50px auto; width: 40%; height: 40px; display: flex; /* space-evenly 第一次見到 */ justify-content: space-evenly; background-color: skyblue; } /* 浮動(dòng)只需要在每個(gè)section里做就行 */ /* 給section設(shè)置"字號(hào)、文本對(duì)齊和行高" => 可繼承屬性 */ .section { float: left; font-size: 16px; line-height: 40px; text-align: center; } /* 這里規(guī)定懸停時(shí)head的樣式 */ /* 也可以寫作.head:hover */ .section:hover .head { color: white; background-color: orange; } /* 整個(gè)menu一開始是看不到的 同時(shí)規(guī)定樣式 */ .menu { display: none; background-color: transparent; } /* 懸停后就可以看到menu了 只能懸停父盒子 */ .section:hover .menu { display: block; } /* 規(guī)定懸停時(shí)li的樣式 */ .menu li:hover { background-color: orange; } </style> </head> <body> <div class="container"> <div class="section"> <a href="#" class="head">寫論文</a> <ul class="menu"> <li>查資料</li> <li>記筆記</li> <li>復(fù)現(xiàn)</li> </ul> </div> <div class="section"> <a href="#" class="head">學(xué)前端</a> <ul class="menu"> <li>HTML</li> <li>CSS</li> <li>JavaScript</li> <li>LeetCode</li> </ul> </div> <div class="section"> <a href="#" class="head">小日子</a> <ul class="menu"> <li>吃飯</li> <li>睡覺</li> <li>打豆豆</li> </ul> </div> </div> </body> </html>
最終效果如下。
Tips:另外還有個(gè)類似的題目是點(diǎn)擊實(shí)現(xiàn)下拉菜單,這個(gè)不一樣的是要添加點(diǎn)擊事件,在JS里寫,之后再補(bǔ)充。也可以選擇將三個(gè)section寫作ul li的形式,這樣嵌套兩層ul也可以實(shí)現(xiàn),語義更好,留給讀者參考。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript 下拉菜單實(shí)現(xiàn)代碼
- css+js下拉菜單
- js動(dòng)態(tài)設(shè)置select下拉菜單的默認(rèn)選中項(xiàng)實(shí)例
- 三級(jí)下拉菜單的js實(shí)現(xiàn)代碼
- 一個(gè)日期下拉菜單的js實(shí)現(xiàn)代碼
- JS實(shí)多級(jí)聯(lián)動(dòng)下拉菜單類,簡單實(shí)現(xiàn)省市區(qū)聯(lián)動(dòng)菜單!
- Js點(diǎn)擊彈出下拉菜單效果實(shí)例
- Javascript仿新浪游戲頻道鼠標(biāo)懸停顯示子菜單效果
- JavaScript鼠標(biāo)懸停事件用法解析
- CSS或者JS實(shí)現(xiàn)鼠標(biāo)懸停顯示另一元素
相關(guān)文章
微信小程序MUI側(cè)滑導(dǎo)航菜單示例(Popup彈出式,左側(cè)不動(dòng),右側(cè)滑動(dòng))
這篇文章主要介紹了微信小程序MUI側(cè)滑導(dǎo)航菜單,結(jié)合實(shí)例形式分析了微信小程序Popup彈出式,左側(cè)不動(dòng),右側(cè)滑動(dòng)菜單相關(guān)實(shí)現(xiàn)技巧與注意事項(xiàng),需要的朋友可以參考下2019-01-01ES6 新增的創(chuàng)建數(shù)組的方法(小結(jié))
這篇文章主要介紹了ES6 新增的創(chuàng)建數(shù)組的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Display SQL Server Version Information
Display SQL Server Version Information...2007-06-06javascript框架設(shè)計(jì)之框架分類及主要功能
這篇文章主要介紹了javascript框架設(shè)計(jì)之框架分類及主要功能的相關(guān)資料,需要的朋友可以參考下2015-06-06使用typescript推導(dǎo)已有變量的盲盒類型詳情
這篇文章主要介紹了使用typescript推導(dǎo)已有變量的盲盒類型詳情,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08js對(duì)table的td進(jìn)行相同內(nèi)容合并示例詳解
正如標(biāo)題所言如何對(duì)table的td進(jìn)行相同內(nèi)容合并,下面為大家詳細(xì)介紹下使用js是如何做到的,感興趣的朋友不要錯(cuò)過2013-12-12關(guān)于foreach循環(huán)中遇到的問題小結(jié)
這篇文章主要介紹了關(guān)于foreach循環(huán)中遇到的問題總結(jié),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-05-05JS庫之Particles.js中文開發(fā)手冊(cè)及參數(shù)詳解
因?yàn)樽约盒枰霎a(chǎn)品,所以一個(gè)好的UI界面也是很重要的,發(fā)現(xiàn)這種散射的原子顆粒特效還不錯(cuò)。今天腳本之家小編把Particles.js中文開發(fā)手冊(cè)及particles.js參數(shù)分享給大家,需要的朋友參考下吧2017-09-09