教你做個可愛的css滑動導(dǎo)航條
嘿!大家好哇,今天來帶大家做一個可愛😊的滑動導(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)航的示例代碼,文中通過示例代碼介紹的非常詳細(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-24CSS實(shí)現(xiàn)移動端橫向滾動導(dǎo)航條(PC端也適用)
這篇文章主要介紹了CSS實(shí)現(xiàn)移動端橫向滾動導(dǎo)航條(PC端也適用),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編2021-03-17
這篇文章主要介紹了CSS 帶搜索導(dǎo)航欄的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)2021-02-22
這篇文章主要介紹了純CSS實(shí)現(xiàn)導(dǎo)航欄下劃線跟隨效果,本文圖文并茂實(shí)例代碼詳解,給大家介紹的非常詳細(xì),需要的朋友參考下吧2019-12-09css實(shí)現(xiàn)流程導(dǎo)航效果(三種方法)
本文通過三種方法給大家介紹css實(shí)現(xiàn)流程導(dǎo)航效果,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下2019-11-13html+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




