前端实现底部tapbar栏代码
AI 概述
今天给大家实现一个好看的底部 tapbar 栏,我们要实现的效果如下:
接着看一下具体实现的代码。
HTML 代码:
<div class="container">
<div class="bar">
<div class="bar-item pre-active" onclick="changeActive(this)">
<div class="bar-fluid"></div>
<div...
今天给大家实现一个好看的底部 tapbar 栏,我们要实现的效果如下:

接着看一下具体实现的代码。
HTML 代码:
<div class="container">
<div class="bar">
<div class="bar-item pre-active" onclick="changeActive(this)">
<div class="bar-fluid"></div>
<div class="drop"></div>
<i class="far fa-calendar-alt"></i>
</div>
<div class="bar-item" onclick="changeActive(this)">
<div class="bar-fluid"></div>
<div class="drop"></div>
<i class="far fa-sticky-note"></i>
</div>
<div class="bar-item" onclick="changeActive(this)">
<div class="bar-fluid"></div>
<div class="drop"></div>
<i class="far fa-bell"></i>
</div>
<div class="bar-item" onclick="changeActive(this)">
<div class="bar-fluid"></div>
<div class="drop"></div>
<i class="far fa-address-book"></i>
</div>
</div>
</div>
CSS 代码:
* {
margin: 0px;
padding: 0px;
box-sizing: border-box;
}
.container {
width: 100%;
height: 100vh;
display: flex;
align-items: center;
justify-content: center;
background-color: #fc5c65;
}
.bar {
padding: 0px 10px;
display: flex;
align-items: center;
background-color: #ffffff;
border-radius: 10px 10px 20px 20px;
box-shadow: 3px 3px 0px 0px rgb(235 59 90);
}
.bar .bar-item {
position: relative;
overflow: hidden;
padding: 20px 25px;
cursor: pointer;
}
.bar .bar-item i {
z-index: 1;
position: relative;
color: #a4b0be;
transition: all .3s ease-in-out;
}
.bar .bar-item.pre-active i {
color: #fc5c65;
}
.bar .bar-item.active i {
color: #fc5c65;
animation: colour 1s ease-in-out;
}
.bar .bar-item.active .bar-fluid {
position: absolute;
top: 0px;
left: 0px;
background-color: #fc5c65;
width: 100%;
height: 0px;
animation: fluid 1s ease-in-out;
}
.bar .bar-item.active .bar-fluid:before {
content: '';
position: absolute;
top: 0px;
left: -50%;
background-color: #ffffff;
width: 110%;
height: 400%;
border-radius: 50%;
}
.bar .bar-item.active .bar-fluid:after {
content: '';
position: absolute;
top: 0px;
right: -50%;
background-color: #ffffff;
width: 110%;
height: 400%;
border-radius: 50%;
}
.bar .bar-item.active .drop {
position: absolute;
top: -2.5px;
left: 30.5px;
background-color: #fc5c65;
width: 2.5px;
height: 2.5px;
border-radius: 50%;
animation: drop 1s ease-in-out;
}
@keyframes colour {
0% { color: #a4b0be; }
55% {
color: #a4b0be;
transform: scale(1);
}
60% {
color: #fc5c65;
transform: scale(1);
}
70% { transform: scale(1.1); }
80% { transform: scale(1); }
}
@keyframes fluid {
0% { height: 0px; }
30% { height: 10px; }
100% { height: 0px; }
}
@keyframes drop {
20% { top: -2.5px; }
50% { top: 21px; }
51% { top: -2.5px; }
}
JavaScript 代码:
const preactiveItem = document.querySelector('.pre-active')
const barItems = document.querySelectorAll('.bar-item')
function changeActive (newActive) {
preactiveItem.classList.remove('pre-active')
barItems.forEach(element => {
element.classList.remove('active')
})
newActive.classList.add('active')
}
看着有点多,没事,自己下去慢慢消化,实在不想消化的就直接做个 CV 工程师,也不是不可以,哈哈。
以上关于前端实现底部tapbar栏代码的文章就介绍到这了,更多相关内容请搜索码云笔记以前的文章或继续浏览下面的相关文章,希望大家以后多多支持码云笔记。
声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » 前端实现底部tapbar栏代码
如若内容造成侵权/违法违规/事实不符,请将相关资料发送至 admin@mybj123.com 进行投诉反馈,一经查实,立即处理!
重要:如软件存在付费、会员、充值等,均属软件开发者或所属公司行为,与本站无关,网友需自行判断
码云笔记 » 前端实现底部tapbar栏代码

微信
支付宝