Rumah > hujung hadapan web > tutorial css > 如何使用纯CSS实现切换按钮时背景的悬停动画效果

如何使用纯CSS实现切换按钮时背景的悬停动画效果

不言
Lepaskan: 2018-08-20 10:08:07
asal
2406 orang telah melayarinya

本篇文章给大家带来的内容是关于如何使用纯CSS实现切换按钮时背景的悬停动画效果,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

效果预览

341040062-5b79e47e984b9_articlex.gif

源代码下载

https://github.com/comehope/front-end-daily-challenges

代码解读

定义 dom,导航中包含一个无序列表,列表中有一个列表项:

<nav>
    <ul>
        <li>home</li>
    </ul>
</nav>
Salin selepas log masuk

居中显示:

body {
    margin: 0;
    height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: teal;
}
Salin selepas log masuk

隐藏列表项前端的引导符号:

nav ul {
    padding: 0;
    list-style-type: none;
}
Salin selepas log masuk

定义按钮容器尺寸:

:root {
    font-size: 10px;
}

nav li {
    width: 20rem;
    height: 7rem;
}
Salin selepas log masuk

设置文字样式:

nav li {
    font-size: 20px;
    text-align: center;
    line-height: 7rem;
    font-family: sans-serif;
    text-transform: uppercase;
    letter-spacing: 1px;
}
Salin selepas log masuk

用伪元素制作 2 个背景色块:

nav li {
    position: relative;
}

nav li::before,
nav li::after {
    content: '';
    position: absolute;
    width: inherit;
    height: inherit;
    top: 0;
    left: 0;
}

nav li::before {
    background-color: white;
    z-index: -1;
}

nav li::after {
    background-color: goldenrod;
    z-index: -2;
}
Salin selepas log masuk

让后面的背景块向右下偏移,并且让前面的背景块投放阴影,增加立体效果:

nav li::before {
    box-shadow: 0.2rem 0.2rem 0.5rem rgba(0, 0, 0, 0.2);
}

nav li::after {
    transform: translate(1.5rem, 1.5rem);
}
Salin selepas log masuk

接下来增加悬停效果。

设置缓动时间,主元素和伪元素都将有缓动效果:

nav li {
    transition: 0.3s;
}

nav li::before,
nav li::after {
    transition: 0.3s;
}
Salin selepas log masuk

当悬停时,2 个背景色块的颜色互换:

nav li:hover::before {
    background-color: goldenrod;
}

nav li:hover::after {
    background-color: white;
}
Salin selepas log masuk

同时,后面的背景色块的向左上方移动,按钮整体则向右下方移动:

nav li:hover {
    transform: translate(1.5rem, 1.5rem);
}

nav li:hover::after {
    transform: translate(-1.5rem, -1.5rem);
}
Salin selepas log masuk

同时,再让文本在悬停时变色:

nav li:hover {
    color: white;
}
Salin selepas log masuk

再增加几个按钮:

<nav>
    <ul>
        <li>home</li>
        <li>products</li>
        <li>services</li>
        <li>contact</li>
    </ul>
</nav>
Salin selepas log masuk

最后,增加按钮之间的间距:

nav li {
    margin: 3rem;
}
Salin selepas log masuk

大功告成!

相关推荐:

如何使用CSS实现一只鸭子头(附代码)

如何使用纯CSS实现一只黑色的愤怒小鸟(附代码)

Atas ialah kandungan terperinci 如何使用纯CSS实现切换按钮时背景的悬停动画效果. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan