本篇內(nèi)容介紹了“CSS怎么實現(xiàn)響應(yīng)式堆疊卡片懸停效果”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
專注于為中小企業(yè)提供成都網(wǎng)站設(shè)計、成都網(wǎng)站制作服務(wù),電腦端+手機端+微信端的三站合一,更高效的管理,為中小企業(yè)西寧免費做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動了1000+企業(yè)的穩(wěn)健成長,幫助中小企業(yè)通過網(wǎng)站建設(shè)實現(xiàn)規(guī)模擴充和轉(zhuǎn)變。
在開始之前,我先介紹一下實現(xiàn)的整體大致思路:首先我們將在 HTM 中設(shè)計一個簡單的卡片結(jié)構(gòu);然后將定義::before 和::after偽元素并將它們相對于父卡片絕對定位;接著使用transform屬性將類“card-inner”的div從其原始位置移開;最后通過使用可以在懸停效果前后translate卡片的變換,在一堆卡片上添加懸停效果。
下面就直接上代碼了!
示例代碼一:
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title></title> <style> body { color: #FDFAF6; background: #50CB93; } .card { position: relative; width: 400px; margin: 60px auto; } .card::before, .card::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; } .card::before, .card::after, .card .card-inner { background-color: #423F3E; border: 1px solid #01937C; transition: transform 0.5s; } .card::before, .card-inner { z-index: 1; } .card-inner { position: relative; padding: 4rem; } /* 將疊好的卡片放在不同的位置 */ .cards:hover { transform: translate(5px, 5px); } .cards:hover::before { transform: translate(-5px, -5px); } .cards:hover::after { transform: translate(-10px, -10px); } </style> </head> <body> <center> <h2>歡迎來到創(chuàng)新互聯(lián)</h2> <div class="card-container"> <div class="card cards"> <div class="card-inner"> <h2>將鼠標(biāo)移至方框內(nèi)</h2> <h4 class="card-title"> 創(chuàng)新互聯(lián) </h4> <div class="card-body"> 編程學(xué)習(xí)平臺 </div> </div> </div> </div> </center> </body> </html>
效果如下:
示例代碼二:
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title></title> <style> body { color: #FDFAF6; background: #50CB93; } :root { --offset-before: 8px; --offset-after: 16px; } .card { position: relative; width: 400px; margin: 60px auto; } .card::before, .card::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; } .card::before, .card::after, .card .card-inner { background-color: #423F3E; border: 1px solid #01937C; transition: transform 0.5s; } .card::before, .card-inner { z-index: 1; } .card-inner { position: relative; padding: 4rem; } .cards-diagonal::before { transform: translate(calc(-1 * 8px), calc(-1 * 8px)); } .cards-diagonal::after { transform: translate(calc(-1 * 16px), calc(-1 * 16px)); } .cards-diagonal:hover::before { transform: translate(8px, 8px); } .cards-diagonal:hover::after { transform: translate(16px, 16px); } .cards-rotate::before, .cards-rotate::after { transform-origin: 50% 100%; } .cards-rotate:hover { transform: translate(2.5px, 0) rotate(2.5deg); } .cards-rotate:hover::before { transform: translate(2.5px, 0) rotate(2.5deg); } .cards-rotate:hover::after { transform: translate(5px, 0) rotate(5deg); } } </style> </head> <body> <center> <h2>歡迎來到創(chuàng)新互聯(lián)</h2> <div class="card-container"> <div class="card cards-diagonal"> <div class="card-inner"> <h2>將鼠標(biāo)移至框內(nèi)</h2> <h4 class="card-title">創(chuàng)新互聯(lián)</h4> <div class="card-body"> 編程學(xué)習(xí)平臺 </div> </div> </div> </div> <div class="card-container"> <div class="card cards-rotate"> <div class="card-inner"> <h2>將鼠標(biāo)移至框內(nèi)</h2> <h4 class="card-title">創(chuàng)新互聯(lián)</h4> <div class="card-body"> 編程學(xué)習(xí)平臺 </div> </div> </div> </div> </center> </body> </html>
效果如下:
示例代碼三:
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <title></title> <style> body { color: #FDFAF6; background: #50CB93; } :root { --offset-before: 8px; --offset-after: 16px; } .card { position: relative; width: 400px; margin: 60px auto; } .card::before, .card::after { content: ""; position: absolute; top: 0; left: 0; width: 100%; height: 100%; } .card::before, .card::after, .card .card-inner { background-color: #423F3E; border: 1px solid #01937C; transition: transform 0.5s; } .card::before, .card-inner { z-index: 1; } .card-inner { position: relative; padding: 4rem; } /*Stacked => Up*/ .cards-up::before, .cards-up::after { transform-origin: center bottom; } .cards-up:hover { transform: translate(0, -5px); } .cards-up:hover::before { transform: translate(0, 5px) scale(0.95); } .cards-up:hover::after { transform: translate(0, 10px) scale(0.90); } /*Stacked => Right */ .cards-right::before, .cards-right::after { transform-origin: left center; } .cards-right:hover { transform: translate(5px, 0); } .cards-right:hover::before { transform: translate(-10px, 0) scale(0.95); } } .cards-right:hover::after { transform: translate(-10px, 0) scale(0.90); } } </style> </head> <body> <center> <h2>歡迎來到創(chuàng)新互聯(lián)</h2> <div class="card-container"> <div class="card cards-up"> <div class="card-inner"> <h2>將鼠標(biāo)移至框內(nèi)</h2> <h4 class="card-title">創(chuàng)新互聯(lián)</h4> <div class="card-body"> 編程學(xué)習(xí)平臺 </div> </div> </div> </div> <div class="card-container"> <div class="card cards-right"> <div class="card-inner"> <h2>將鼠標(biāo)移至框內(nèi)</h2> <h4 class="card-title">創(chuàng)新互聯(lián)</h4> <div class="card-body"> 編程學(xué)習(xí)平臺 </div> </div> </div> </div> </center> </body> </html>
效果如下:
“CSS怎么實現(xiàn)響應(yīng)式堆疊卡片懸停效果”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!
網(wǎng)站欄目:CSS怎么實現(xiàn)響應(yīng)式堆疊卡片懸停效果
本文鏈接:http://www.rwnh.cn/article28/psgpjp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號、自適應(yīng)網(wǎng)站、域名注冊、外貿(mào)建站、服務(wù)器托管、關(guān)鍵詞優(yōu)化
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)