JavaScript實(shí)現(xiàn)二級(jí)菜單的制作
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)二級(jí)菜單效果的具體代碼,供大家參考,具體內(nèi)容如下
這次實(shí)現(xiàn)的效果圖如下:
這個(gè)二級(jí)菜單實(shí)現(xiàn)的效果是:
當(dāng)點(diǎn)擊某一個(gè)框時(shí),會(huì)將已經(jīng)打開的框的內(nèi)容收回,再展開現(xiàn)在點(diǎn)擊的框的內(nèi)容。
那要如何實(shí)現(xiàn)這個(gè)效果呢?
我們可以step by step
1、首先我們要將整個(gè)框架顯示出來(lái),即所有框展開的樣子,因?yàn)槠滹@示/不顯示是拿overflow:hidden
做的。
但是要注意不要所有的框都拿一種類型的盒子做,因?yàn)槟菢硬环奖銓慾s代碼,畢竟我們之后的操作是點(diǎn)擊綠色的框=>使得收起或展開白色的框,所以我們需要為每一個(gè)天數(shù)+對(duì)應(yīng)課程的框放在一個(gè)div父盒子下。然后為其初始化:設(shè)置高度等于span的高度,設(shè)置overflow:hidden
,如下圖,可以結(jié)合下面代碼
2、然后開始寫js部分:確保點(diǎn)擊某一框時(shí),它會(huì)由閉合變?yōu)檎归_。我們的框是span,如果想要span的父盒子div中的內(nèi)容全部顯示,我們首先需要通過(guò)document.getElementsByTagName("span")
獲取所有的span,然后利用for循環(huán)在每一個(gè)span的onclick
響應(yīng)函數(shù)中通過(guò)parentNode
獲取其對(duì)應(yīng)的父盒子,使其父盒子的高度變?yōu)槠?code>scrollHeight的值
3、然后我們需要在點(diǎn)擊span使某盒子展開的時(shí)候,將已經(jīng)展開的盒子收起。這時(shí)我們就需要一個(gè)變量now來(lái)記錄上次被點(diǎn)擊的盒子,令其初值為null,若now不等于當(dāng)前點(diǎn)擊的span,則獲取now的父盒子,令其高度變?yōu)閟pan的高度,然后令當(dāng)前點(diǎn)擊的span展開(第二點(diǎn)已經(jīng)講了怎么展開);若now等于當(dāng)前點(diǎn)擊的span,獲取其父盒子的高度,如果等于span的高度,則令其高度變?yōu)?code>scrollHeight的值,否則令其變?yōu)閟pan的高度
4、設(shè)置定時(shí)器,在準(zhǔn)備將父盒子高度增加或減少的時(shí)候調(diào)用,當(dāng)父盒子高度達(dá)到span的高度或達(dá)到scrollHeight
,就關(guān)閉定時(shí)器(可以設(shè)置兩個(gè)定時(shí)器)
代碼如下:
<!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>Document</title> <style> * { margin: 0; padding: 0; } .container { width: 300px; height: 700px; margin: 100px auto; } .container div { height: 43px; overflow: hidden; } .container div span { width: 150px; height: 40px; line-height: 40px; border-radius: 15px; display: block; text-align: center; background-color: rgba(104, 250, 201, 0.849); cursor: pointer; } a { width: 150px; height: 40px; line-height: 40px; text-decoration: none; display: block; text-align: center; } </style> </head> <body> <div class="container"> <div id=""> <span id="one">周一</span> <a href="">可視化</a> <a href="">可視化</a> </div> <div id=""> <span id="two">周二</span> <a href="">算法設(shè)計(jì)</a> <a href="">圖形學(xué)</a> <a href="">計(jì)組課設(shè)</a> <a href="">操作系統(tǒng)</a> </div> <div id=""> <span id="three">周四</span> <a href="">形勢(shì)與政策</a> <a href="">操作系統(tǒng)</a> </div> <div id=""> <span id="four">周五</span> <a href="">算法設(shè)計(jì)</a> </div> </div> <script> let menu = document.getElementsByTagName("span"); let now = null; for (let i = 0; i < menu.length; i++) { menu[i].onclick = function () { let par = menu[i].parentNode; if (now === i) { if (par.style.height === "43px") { open(par); } else { close(par); } } else { if (now !== null) { close(menu[now].parentNode); } open(par); now = i; } } } function open(par) { let tem = setInterval(() => { let num = par.offsetHeight; if (num >= par.scrollHeight) { clearInterval(tem); } par.style.height = num + 1 + "px"; }, 7); } function close(par) { let tem = setInterval(() => { let num = par.offsetHeight; if (num <= 43) { clearInterval(tem); return; } par.style.height = num - 1 + "px"; }, 7); } </script> </body> </html>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 通用的二級(jí)菜單代碼(css+javascript)
- 簡(jiǎn)單實(shí)現(xiàn)js點(diǎn)擊展開二級(jí)菜單功能
- vue.js 左側(cè)二級(jí)菜單顯示與隱藏切換的實(shí)例代碼
- 鼠標(biāo)經(jīng)過(guò)顯示二級(jí)菜單js特效
- js實(shí)現(xiàn)向右橫向滑出的二級(jí)菜單效果
- javascript鼠標(biāo)滑過(guò)顯示二級(jí)菜單特效
- vue.js實(shí)現(xiàn)二級(jí)菜單效果
- JS實(shí)現(xiàn)超精簡(jiǎn)響應(yīng)鼠標(biāo)顯示二級(jí)菜單代碼
- js實(shí)現(xiàn)二級(jí)菜單點(diǎn)擊顯示當(dāng)前內(nèi)容效果
- JavaScript+CSS實(shí)現(xiàn)的可折疊二級(jí)菜單實(shí)例
相關(guān)文章
JavaScript隱式類型轉(zhuǎn)換代碼實(shí)例
這篇文章主要介紹了JavaScript隱式類型轉(zhuǎn)換代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05js實(shí)現(xiàn)StringBuffer的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇js實(shí)現(xiàn)StringBuffer的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09js 變量類型轉(zhuǎn)換常用函數(shù)與代碼[比較全]
腳本之家收集了一些 數(shù)字與字符之間的轉(zhuǎn)換,數(shù)組轉(zhuǎn)為字符等函數(shù)代碼。2009-12-12無(wú)循環(huán) JavaScript(map、reduce、filter和find)
本文由淺入深地介紹了map、reduce、filter和find函數(shù),如何一步一步把循環(huán)從代碼中抽離掉2017-04-04js 動(dòng)態(tài)修改css文件用到了cssRule
js 動(dòng)態(tài)修改css文件,循環(huán)用的underscore,在使用cssRule只能使用cssRule.style.padding=0px,詳細(xì)示例如下2014-08-08微信小程序項(xiàng)目實(shí)踐之驗(yàn)證碼倒計(jì)時(shí)功能
這篇文章主要介紹了微信小程序項(xiàng)目實(shí)踐之驗(yàn)證碼倒計(jì)時(shí)功能,當(dāng)用戶點(diǎn)擊發(fā)送驗(yàn)證碼按鈕,按鈕背景變色,不可點(diǎn)擊,顯示倒計(jì)時(shí)文字,需要的朋友可以參考下2018-07-07JavaScript實(shí)現(xiàn)京東購(gòu)物放大鏡和選項(xiàng)卡效果的方法分析
這篇文章主要介紹了JavaScript實(shí)現(xiàn)京東購(gòu)物放大鏡和選項(xiàng)卡效果的方法,結(jié)合實(shí)例形式分析了javascript基于事件響應(yīng)、數(shù)值計(jì)算與頁(yè)面元素動(dòng)態(tài)修改實(shí)現(xiàn)圖片放大功能以及tab選項(xiàng)卡切換效果相關(guān)操作技巧,需要的朋友可以參考下2018-07-07js實(shí)現(xiàn)三張圖(文)片一起切換的banner焦點(diǎn)圖
這篇文章主要介紹了js實(shí)現(xiàn)三張圖(文)片一起切換的banner焦點(diǎn)圖,推薦給大家,有需要的小伙伴可以參考下。2015-08-08FireFox與IE 下js兼容觸發(fā)click事件的代碼
FireFox與IE 下js兼容觸發(fā)click事件 ,對(duì)于需要兼容這兩者的朋友,就需要參考下下面的代碼了2008-11-11