欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript實(shí)現(xiàn)二級(jí)菜單的制作

 更新時(shí)間:2021年10月26日 10:56:45   作者:wait......  
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)二級(jí)菜單的制作,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(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í)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論