怎么使用純CSS實(shí)現(xiàn)切換按鈕時(shí)背景的懸停動(dòng)畫效果

小編給大家分享一下怎么使用純CSS實(shí)現(xiàn)切換按鈕時(shí)背景的懸停動(dòng)畫效果,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于網(wǎng)站設(shè)計(jì)制作、網(wǎng)站設(shè)計(jì)、臨海網(wǎng)絡(luò)推廣、微信小程序、臨海網(wǎng)絡(luò)營(yíng)銷、臨海企業(yè)策劃、臨海品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營(yíng)等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供臨海建站搭建服務(wù),24小時(shí)服務(wù)熱線:13518219792,官方網(wǎng)址:muchs.cn

效果預(yù)覽

怎么使用純CSS實(shí)現(xiàn)切換按鈕時(shí)背景的懸停動(dòng)畫效果

源代碼下載

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

代碼解讀

定義 dom,導(dǎo)航中包含一個(gè)無序列表,列表中有一個(gè)列表項(xiàng):

<nav>
    <ul>
        <li>home</li>
    </ul>
</nav>

居中顯示:

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

隱藏列表項(xiàng)前端的引導(dǎo)符號(hào):

nav ul {
    padding: 0;
    list-style-type: none;
}

定義按鈕容器尺寸:

:root {
    font-size: 10px;
}

nav li {
    width: 20rem;
    height: 7rem;
}

設(shè)置文字樣式:

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

用偽元素制作 2 個(gè)背景色塊:

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;
}

讓后面的背景塊向右下偏移,并且讓前面的背景塊投放陰影,增加立體效果:

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);
}

接下來增加懸停效果。

設(shè)置緩動(dòng)時(shí)間,主元素和偽元素都將有緩動(dòng)效果:

nav li {
    transition: 0.3s;
}

nav li::before,
nav li::after {
    transition: 0.3s;
}

當(dāng)懸停時(shí),2 個(gè)背景色塊的顏色互換:

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

nav li:hover::after {
    background-color: white;
}

同時(shí),后面的背景色塊的向左上方移動(dòng),按鈕整體則向右下方移動(dòng):

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

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

同時(shí),再讓文本在懸停時(shí)變色:

nav li:hover {
    color: white;
}

再增加幾個(gè)按鈕:

<nav>
    <ul>
        <li>home</li>
        <li>products</li>
        <li>services</li>
        <li>contact</li>
    </ul>
</nav>

最后,增加按鈕之間的間距:

nav li {
    margin: 3rem;
}

看完了這篇文章,相信你對(duì)怎么使用純CSS實(shí)現(xiàn)切換按鈕時(shí)背景的懸停動(dòng)畫效果有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

網(wǎng)站標(biāo)題:怎么使用純CSS實(shí)現(xiàn)切換按鈕時(shí)背景的懸停動(dòng)畫效果
網(wǎng)頁路徑:http://muchs.cn/article14/gcecde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作建站公司、商城網(wǎng)站、企業(yè)建站、手機(jī)網(wǎng)站建設(shè)小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化