溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

怎么使用純CSS實(shí)現(xiàn)手風(fēng)琴效果

發(fā)布時(shí)間:2021-03-19 11:44:33 來源:億速云 閱讀:405 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)怎么使用純CSS實(shí)現(xiàn)手風(fēng)琴效果,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

實(shí)現(xiàn)原理:

怎么使用純CSS實(shí)現(xiàn)手風(fēng)琴效果

主要是利用CSS的hover屬性,鼠標(biāo)未移上去時(shí),所有的li共享整個(gè)容器的寬度。當(dāng)鼠標(biāo)移上去的時(shí)候,hover生效,讓該li標(biāo)簽變回原來圖片的寬度,其他的圖共享剩下的寬度。同時(shí)加上transition屬性,產(chǎn)生漸變的效果。

接下來通過一個(gè)小小的demo來切身感受一下:

HTML代碼:

<body>
        <div class="contain">
            <ul>
                <li>
                    <a href="#">
                        <img src="img/1.jpg" />
                    </a>
                    <div class="title">
                        <a href="#">云南.大理</a>
                    </div>
                </li>
                <li>
                    <a href="#">
                        <img src="img/2.jpg" />
                    </a>
                    <div class="title">
                        <a href="#">廣西.桂林</a>
                    </div>
                </li>
                <li>
                    <a href="#">
                        <img src="img/3.jpg" />
                    </a>
                    <div class="title">
                        <a href="#">福建.廈門</a>
                    </div>
                </li>
                <li>
                    <a href="#">
                        <img src="img/4.jpg" />
                    </a>
                    <div class="title">
                        <a href="#">浙江.千島湖</a>
                    </div>
                </li>
                <li>
                    <a href="#">
                        <img src="img/5.jpg" />
                    </a>
                    <div class="title">
                        <a href="#">長江.三峽</a>
                    </div>
                </li>
            </ul>
        </div>
</body>

CSS代碼:

.contain {
            width: 1050px;
            margin: 100px auto;
        }
        
        .contain li {
            float: left;
            list-style: none;
            width: 200px;
            height:284px;
            transition: all 2s;
            position: relative;
            overflow: hidden;
            border-left: 2px solid rgba(255, 255, 255, .8);
            box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.8);
        }
        
        .contain ul:hover li {
            width: 80px;
        }
        
        .contain ul li:hover {
            width: 500px;
        }
        
        .contain li .title {
            position: absolute;
            width: 100%;
            height: 50px;
            background-color: rgba(0, 0, 0, .5);
            text-indent: 2em;
            line-height: 50px;
            bottom: 0px;
            left: 0
        }
        
        .contain a {
            color: #fff;
            text-decoration: none;
        }

實(shí)現(xiàn)效果圖如下:

怎么使用純CSS實(shí)現(xiàn)手風(fēng)琴效果

鼠標(biāo)未移上去時(shí)效果

怎么使用純CSS實(shí)現(xiàn)手風(fēng)琴效果

鼠標(biāo)移到某張圖片效果

這是一個(gè)很簡單的小demo,容易上手,對于初學(xué)者來說也并不難。同時(shí)也通過這個(gè)demo感受到了CSS的強(qiáng)大與魅力之處,希望能給大家?guī)硪稽c(diǎn)小小的幫助。最后梳理一下,做一下這個(gè)demo中所用的知識(shí)點(diǎn)做一個(gè)總結(jié):

1.hover 選擇器

解釋::hover 選擇器用于選擇鼠標(biāo)指針浮動(dòng)在上面的元素。:hover 選擇器可用于所有元素,不只是鏈接。

補(bǔ)充::link 選擇器設(shè)置指向未被訪問頁面的鏈接的樣式,:visited 選擇器用于設(shè)置指向已被訪問的頁面的鏈接,:active 選擇器用于活動(dòng)鏈接。

拓展:在 CSS 定義中,:hover 必須位于 :link 和 :visited 之后(如果存在的話),這樣樣式才能生效。

2.transition屬性

解釋:transition是CSS3一個(gè)簡寫屬性,用于設(shè)置四個(gè)過渡屬性:

  1. transition-property:規(guī)定設(shè)置過渡效果的 CSS 屬性的名稱。

  2. transition-duration:規(guī)定完成過渡效果需要多少秒或毫秒。

  3. transition-timing-function:規(guī)定速度效果的速度曲線。

  4. transition-delay:定義過渡效果何時(shí)開始。

語法:transition: property duration timing-function delay;

關(guān)于“怎么使用純CSS實(shí)現(xiàn)手風(fēng)琴效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI