<div class="box">
<div class="container" id="my">
<div class="item" v-for="(el,index) in item" :key="index" @click="isNum=index" :class="isNum==index?'active':''">
<img :src="el.imge" alt="">
<p class="text">{{el.name}}</p>
</div>
<div class="plus"></div>
</div>
</div>
data() {
return {
isNum: 1,
item: [
{ imge: require('../assets/20.png'), name: '首页' },
{ imge: require('../assets/30.png'), name: '首页' },
{ imge: require('../assets/40.png'), name: '首页' },
{ imge: require('../assets/50.png'), name: '首页' },
]
}
}
<style>
* {
margin: 0;
padding: 0;
}
.container {
width: 400px;
height: 70px;
background-color: blue;
display: flex;
align-items: center;
justify-content: space-around;
text-align: center;
color: #fff;
position: relative;
top: 50%;
left: 50%;
transform: translate(-50%, 100%);
}
.container .item img {
width: 20px;
height: 20px;
}
.container .item {
display: flex;
flex-direction: column;
align-items: center;
justify-content: center;
cursor: pointer;
}
.plus {
position: absolute;
left: 10px;
top: -58%;
background-color: rgb(231, 209, 7);
width: 70px;
height: 70px;
border-radius: 50%;
display: flex;
justify-content: center;
align-items: center;
border: 6px solid #fff;
/* 过渡 */
transition: 0.5s;
}
/* 圆弧 */
.plus::before {
content: "";
position: absolute;
/* background: blue; */
border-top-right-radius: 20px;
width: 20px;
height: 20px;
top: 50%;
left: -20px;
box-shadow: 0 -10px 0 0 #fff;
}
.plus::after {
content: "";
position: absolute;
border-top-left-radius: 20px;
width: 20px;
height: 20px;
top: 50%;
right: -20px;
box-shadow: 0 -10px 0 0 #fff;
}
/* 选中样式 未选中样式 */
/* 未选中样式 文字 位移 不显示 */
.container .item img {
position: absolute;
font-size: 24px;
/* 过渡 */
transition: 0.5s;
}
.text {
opacity: 0;
font-weight: 600;
transform: translateY(20px);
/* 过渡 */
transition: 0.5s;
}
/* 选中样式 */
.item.active img {
transform: translateY(-30px);
z-index:99;
}
.item.active .text {
opacity: 1;
transform: translateY(15px);
}
.item:nth-child(1).active ~ .plus {
transform: translateX(calc(100px * 0));
}
.item:nth-child(2).active ~ .plus {
transform: translateX(calc(100px * 1));
}
.item:nth-child(3).active ~ .plus {
transform: translateX(calc(100px * 2));
}
.item:nth-child(4).active ~ .plus {
transform: translateX(calc(100px * 3));
}
tabbar导航栏动画 自定义
crush_yyqx2023-08-05 23:31
相关推荐
桂月二二4 小时前
探索前端开发中的 Web Vitals —— 提升用户体验的关键技术CodeClimb5 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】沈梦研5 小时前
【Vscode】Vscode不能执行vue脚本的原因及解决方法hunter2062065 小时前
ubuntu向一个pc主机通过web发送数据,pc端通过工具直接查看收到的数据qzhqbb5 小时前
web服务器 网站部署的架构刻刻帝的海角5 小时前
CSS 颜色轻口味6 小时前
Vue.js 组件之间的通信模式浪浪山小白兔6 小时前
HTML5 新表单属性详解lee5767 小时前
npm run dev 时直接打开Chrome浏览器2401_897579657 小时前
AI赋能Flutter开发:ScriptEcho助你高效构建跨端应用