在如今的網頁設計中,視覺效果的重要性越來越受到重視,而CSS拓撲線條流動效果是其中的一大熱門。
這種效果通過利用CSS的繪制能力和動畫效果,將靜態的線條轉化為流動的曲線,給用戶帶來視覺上的驚喜。
.wrapper {
position: relative;
width: 80%;
margin: 0 auto;
height: 400px;
display: flex;
justify-content: center;
align-items: center;
}
.wrapper span {
position: absolute;
width: 200px;
height: 200px;
border-radius: 50%;
background-color: #1E90FF;
box-shadow: 0 0 10px #1E90FF;
animation: wave 2s infinite linear;
transform: translateY(-100px);
}
.wrapper span:nth-child(2) {
width: 180px;
height: 180px;
background-color: transparent;
border: 5px dashed #1E90FF;
box-shadow: none;
transform: translateY(100px);
animation-delay: 0.5s;
}
.wrapper span:nth-child(3) {
width: 160px;
height: 160px;
background-color: transparent;
border: 5px solid #1E90FF;
box-shadow: none;
animation-delay: 1s;
transform: translateY(-100px);
}
.wrapper span:nth-child(4) {
width: 140px;
height: 140px;
background-color: #1E90FF;
border: none;
animation-delay: 1.5s;
transform: translateY(100px);
}
@keyframes wave {
0% {
transform: translateY(-100px);
}
25% {
transform: translateY(0);
}
50% {
transform: translateY(100px);
}
75% {
transform: translateY(0);
}
100% {
transform: translateY(-100px);
}
}
如上是一段實現拓撲線條流動效果的代碼。可以看到,在.wrapper中,我們使用了flex布局使得所有的span都在容器中央,然后通過nth-child來依次設定每個span的樣式,從而形成一個類似于波動的效果。通過對keyframe的調整,可以自行設定各種有意思的運動軌跡。
不管是在網站首頁的banner區域還是在單個頁面的某個小塊內,拓撲線條流動效果總有不錯的應用場景,帶來與眾不同的視覺體驗。