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

教你做個可愛的css滑動導(dǎo)航條

  發(fā)布時間:2021-06-15 15:54:11   作者:小丞同學(xué)   我要評論
今天來帶大家做一個可愛的滑動導(dǎo)航欄效果,這個demo很基礎(chǔ),但是使用場景非常廣泛,感興趣的小伙伴們可以參考一下

嘿!大家好哇,今天來帶大家做一個可愛😊的滑動導(dǎo)航欄效果,這個demo很基礎(chǔ),但是使用場景非常廣泛噢 :happy: !作為前端大白,今天就手把手一步一步教你實(shí)現(xiàn)它吧!❤️

實(shí)現(xiàn)效果

看!這個滑動的效果很有趣吧!這樣的滑動效果相信你一定有想過吧!✋

實(shí)現(xiàn)過程

1. 前期準(zhǔn)備

雖然這個控件很小,功能也不是很多,但我們還是需要先分析一下它的結(jié)構(gòu),以及實(shí)現(xiàn)的功能

鼠標(biāo)移入對應(yīng)的列表項(xiàng),底部的線會滑到相應(yīng)的位置

點(diǎn)擊相應(yīng)的列表項(xiàng),背景滑塊會切換到所選擇的列表項(xiàng)

<div class="slipNav">
    <nav>
        <a href="javascript:;" class="selected">首頁</a>
        <a href="javascript:;">我的</a>
        <a href="javascript:;">聯(lián)系</a>
        <a href="javascript:;">訂閱</a>
        <a href="javascript:;">管理</a>
        <a href="javascript:;">相冊</a>
        <!-- 底部線條 -->
        <div class="line"></div>
        <!-- 背景滑塊 -->
        <div class="bgc"></div>
    </nav>
</div>

通過上面簡單的分析,我們可以寫出html結(jié)構(gòu),在基本列表項(xiàng)的基礎(chǔ)上添加了一個線條和滑塊:happy:

2. 使用CSS對導(dǎo)航條進(jìn)行修飾

這部分很簡單沒有涉及什么難得屬性,相信聰明可愛的你一定信手拈來:happy:

首先我們先對整個導(dǎo)航欄進(jìn)行一些調(diào)整,給導(dǎo)航欄添加了背景顏色,同時添加一定的圓角,讓整個導(dǎo)航欄看起來圓嘟嘟😊,由于后面內(nèi)部的標(biāo)簽使用了浮動和定位,所以這里需要清除浮動噢!

.slipNav nav {
    position: relative;
    background-color: white;
    border-radius: 50px;
}

.slipNav nav::after {
    content: '';
    display: block;
    clear: both;
}

tips:清除浮動的三件套要牢記噢!

接下來我們對每一個列表項(xiàng)進(jìn)行美化吧!調(diào)整字體大小,行高使得文本狀態(tài)最佳 ☘️ !

.slipNav a {
    position: relative;
    float: left;
    width: 150px;
    line-height: 50px;
    text-align: center;
    font-size: 18px;
    color: #000;
    z-index: 1;
}

下面來對底部線條以及背景滑塊進(jìn)行加工吧,通過絕對定位的方式定位到默認(rèn)選擇文本的下方,背景滑塊也是同理!

.line {
    position: absolute;
    top: 50px;
    left: 35px;
    /* 線的長寬 */
    height: 3px;
    width: 80px;
    background-color: #54a0ff;
    transition: all .3s;
}

.bgc {
    position: absolute;
    top: 0px;
    left: 25px;
    height: 50px;
    width: 100px;
    border-radius: 50px;
    background-color: rgb(84, 126, 233);
    transition: all .3s;
}

3. 使用JS來實(shí)現(xiàn)線條滑塊的功能

在上面的美化過程中,我們對線條以及背景滑塊采用了絕對定位,就是為了下面通過控制left值來控制它們的位置變化!下面就來實(shí)現(xiàn)吧!

實(shí)現(xiàn)功能:鼠標(biāo)移入對應(yīng)的列表項(xiàng),底部的線會滑到相應(yīng)的位置

由于導(dǎo)航條中的項(xiàng)目過多,在后面查找對應(yīng)元素索引時會比較麻煩,所以我們先給所有的列表項(xiàng)添加一個自定義屬性data-index來代表他們的索引

let slipAll = document.querySelectorAll('.slipNav nav a');
//給所有的a標(biāo)簽添加index屬性,方便后面查找
for (let i = 0; i < slipAll.length; i++) {
    slipAll[i].setAttribute('data-index', i)
}

接下來我們通過監(jiān)聽鼠標(biāo)移入的位置來計算線的left值,

這里通過事件委托來實(shí)現(xiàn),通過獲取觸發(fā)事件的index屬性來計算left值,當(dāng)鼠標(biāo)移出導(dǎo)航欄時,由于沒有選擇其他的項(xiàng),所以線條需要回到原先被選中元素的位置

//鼠標(biāo)移入底下的線跟著移動
slipNav.addEventListener('mouseover', function (e) {
    let target = e.target
    let len = 150 * target.dataset.index + 35;// 計算當(dāng)前的left值
    line.style.left = len + 'px';
})
//鼠標(biāo)移出時底下的線回到原來的位置
slipNav.addEventListener('mouseleave', function (e) {
    let selected = document.querySelector('.slipNav .selected')//原先被選中的元素
    let len = 150 * selected.dataset.index + 35 // 線回到被選擇元素的位置
    line.style.left = len + 'px'
})

注意:由于在css代碼中設(shè)置了過渡屬性,所以在改變left值時,不會突變而是一個滑動過程噢!😉

實(shí)現(xiàn)功能:點(diǎn)擊相應(yīng)的列表項(xiàng),背景滑塊會切換到所選擇的列表項(xiàng)

當(dāng)我們鼠標(biāo)點(diǎn)擊列表項(xiàng)時,我們需要選中當(dāng)前元素,背景塊需要定位到當(dāng)前位置!實(shí)現(xiàn)方法相同

//鼠標(biāo)點(diǎn)擊時背景顏色的滑塊滑倒相應(yīng)的位置
slipNav.addEventListener('click', function (e) {
    let target = e.target;
    let bgc = document.querySelector('.bgc')
    //排他思想
    for (let i = 0; i < slipAll.length; i++) {
        slipAll[i].classList.remove('selected')
    }
    target.classList.add('selected');// 通過添加類名實(shí)現(xiàn)顏色變化
    let len = 150 * target.dataset.index + 25 // 計算背景滑塊left值
    bgc.style.left = len + 'px';
})

完整代碼

需要代碼可以直接復(fù)制噢!

<!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;
        }

        body {
            background-color: rgb(221, 230, 245);
        }

        a {
            color: inherit;
            text-decoration: none;
        }

        .slipNav {
            width: 920px;
            margin: 100px auto;
        }

        .slipNav a {
            position: relative;
            float: left;
            width: 150px;
            line-height: 50px;
            text-align: center;
            font-size: 18px;
            color: #000;
            z-index: 1;
        }

        .slipNav nav {
            position: relative;
            background-color: white;
            border-radius: 50px;
        }

        .slipNav nav::after {
            content: '';
            display: block;
            clear: both;
        }

        .slipNav nav :hover {
            color: #54a0ff;
        }

        .selected {
            color: white !important;
        }

        .line {
            position: absolute;
            top: 50px;
            left: 35px;
            /* 線的長寬 */
            height: 3px;
            width: 80px;
            background-color: #54a0ff;
            transition: all .3s;
        }

        .bgc {
            position: absolute;
            top: 0px;
            left: 25px;
            /* 線的長寬 */
            height: 50px;
            width: 100px;
            border-radius: 50px;
            background-color: rgb(84, 126, 233);
            transition: all .3s;
        }
    </style>
</head>

<body>
    <div class="slipNav">
        <nav>
            <a href="javascript:;" class="selected">首頁</a>
            <a href="javascript:;">我的</a>
            <a href="javascript:;">聯(lián)系</a>
            <a href="javascript:;">訂閱</a>
            <a href="javascript:;">管理</a>
            <a href="javascript:;">相冊</a>
            <!-- 底部線條 -->
            <div class="line"></div>
            <!-- 背景滑塊 -->
            <div class="bgc"></div>
        </nav>
    </div>
    <script>
        let line = document.querySelector('.line');
        let slipNav = document.querySelector('.slipNav nav');
        let slipAll = document.querySelectorAll('.slipNav nav a');
        //給所有的a標(biāo)簽添加index屬性,方便后面查找
        for (let i = 0; i < slipAll.length; i++) {
            slipAll[i].setAttribute('data-index', i)
        }
        //鼠標(biāo)移入底下的線跟著移動
        slipNav.addEventListener('mouseover', function (e) {
            let target = e.target
            let len = 150 * target.dataset.index + 35;// 計算當(dāng)前的left值
            line.style.left = len + 'px';
        })
        //鼠標(biāo)移出時底下的線回到原來的位置
        slipNav.addEventListener('mouseleave', function (e) {
            let selected = document.querySelector('.slipNav .selected')
            let len = 150 * selected.dataset.index + 35 // 線回到被選擇元素的位置
            line.style.left = len + 'px'
        })
        //鼠標(biāo)點(diǎn)擊時背景顏色的滑塊滑倒相應(yīng)的位置
        slipNav.addEventListener('click', function (e) {
            let target = e.target;
            let bgc = document.querySelector('.bgc')
            //排他思想
            for (let i = 0; i < slipAll.length; i++) {
                slipAll[i].classList.remove('selected')
            }
            target.classList.add('selected');// 通過添加類名實(shí)現(xiàn)顏色變化
            let len = 150 * target.dataset.index + 25 // 計算背景滑塊left值
            bgc.style.left = len + 'px';
        })
    </script>
</body>

</html>

噢!完成了!以上就是本次demo的完整代碼噢,感興趣的你可以動手試試噢!相信一定會有所收獲噢!

到此這篇關(guān)于教你做個可愛的css滑動導(dǎo)航條的文章就介紹到這了,更多相關(guān)css滑動導(dǎo)航條內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持腳本之家!

相關(guān)文章

  • css旋轉(zhuǎn)導(dǎo)航的示例代碼

    本文主要介紹了css旋轉(zhuǎn)導(dǎo)航的示例代碼,文中通過示例代碼介紹的非常詳細(xì),該導(dǎo)航可用在一些網(wǎng)站首頁導(dǎo)航欄中,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-27
  • CSS+HTML 實(shí)現(xiàn)頂部導(dǎo)航欄功能

    這篇文章主要介紹了CSS+HTML 實(shí)現(xiàn)頂部導(dǎo)航欄功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-24
  • CSS實(shí)現(xiàn)移動端橫向滾動導(dǎo)航條(PC端也適用)

    這篇文章主要介紹了CSS實(shí)現(xiàn)移動端橫向滾動導(dǎo)航條(PC端也適用),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編
    2021-03-17
  • CSS 帶搜索導(dǎo)航欄的示例代碼

    這篇文章主要介紹了CSS 帶搜索導(dǎo)航欄的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)
    2021-02-22
  • 不可思議的CSS導(dǎo)航欄下劃線跟隨效果

    這篇文章主要介紹了純CSS實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨效果,本文圖文并茂實(shí)例代碼詳解,給大家介紹的非常詳細(xì),需要的朋友參考下吧
    2019-12-09
  • css實(shí)現(xiàn)流程導(dǎo)航效果(三種方法)

    本文通過三種方法給大家介紹css實(shí)現(xiàn)流程導(dǎo)航效果,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下
    2019-11-13
  • html+css 實(shí)現(xiàn)簡易導(dǎo)航欄功能

    這篇文章主要介紹了基于html+css 實(shí)現(xiàn)簡易導(dǎo)航欄功能,主要就是css(級聯(lián)樣式表)對html的內(nèi)容做格式化。具體內(nèi)容詳情大家跟隨小編一起通過本文學(xué)習(xí)吧
    2021-04-07
  • css實(shí)現(xiàn)導(dǎo)航切換的實(shí)例代碼

    本文通過實(shí)例代碼給大家介紹了css實(shí)現(xiàn)導(dǎo)航切換效果,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-08-15
  • css實(shí)現(xiàn)電梯導(dǎo)航的項(xiàng)目實(shí)踐

    CSS梯形導(dǎo)航圖是一種使用 CSS 布局實(shí)現(xiàn)的導(dǎo)航設(shè)計,可以根據(jù)需要靈活調(diào)整導(dǎo)航菜單的上下位置和大小,本文主要介紹了css實(shí)現(xiàn)電梯導(dǎo)航,具有一定的參考價值,感興趣的可以了解
    2023-05-06

最新評論