搜尋
首頁web前端css教學純CSS實現手風琴效果範例詳解

純CSS實現手風琴效果範例詳解

Dec 29, 2017 pm 05:02 PM
css手風琴

本文主要介紹了用純CSS實現手風琴效果的範例程式碼的相關資料,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟著小編過來看看吧,希望能幫助大家。

昨天在做一個旅遊頁面的項目,前端頁面實現的過程中遇到這樣一個需求。需要把一組圖片形成手風琴的展示效果。認真的思考一遍後,決定就用普通的HTML+CSS就可以實現這個需求。今天趁著空閒時間稍微梳了一下。

實作原理:

主要利用CSS的hover屬性,當滑鼠未移上去時,所有的li共享整個容器的寬度。當滑鼠移上去的時候,hover生效,讓該li標籤變回原來圖片的寬度,其他的圖共享剩餘的寬度。同時加上transition屬性,產生漸層的效果。

接下來透過一個小小的demo來切身感受一下:

HTML程式碼:


<body>
        <p class="contain">
            <ul>
                <li>
                    <a href="#">
                        <img  src="/static/imghwm/default1.png"  data-src="img/1.jpg"  class="lazy"   / alt="純CSS實現手風琴效果範例詳解" >
                    </a>
                    <p class="title">
                        <a href="#">云南.大理</a>
                    </p>
                </li>
                <li>
                    <a href="#">
                        <img  src="/static/imghwm/default1.png"  data-src="img/2.jpg"  class="lazy"   / alt="純CSS實現手風琴效果範例詳解" >
                    </a>
                    <p class="title">
                        <a href="#">广西.桂林</a>
                    </p>
                </li>
                <li>
                    <a href="#">
                        <img  src="/static/imghwm/default1.png"  data-src="img/3.jpg"  class="lazy"   / alt="純CSS實現手風琴效果範例詳解" >
                    </a>
                    <p class="title">
                        <a href="#">福建.厦门</a>
                    </p>
                </li>
                <li>
                    <a href="#">
                        <img  src="/static/imghwm/default1.png"  data-src="img/4.jpg"  class="lazy"   / alt="純CSS實現手風琴效果範例詳解" >
                    </a>
                    <p class="title">
                        <a href="#">浙江.千岛湖</a>
                    </p>
                </li>
                <li>
                    <a href="#">
                        <img  src="/static/imghwm/default1.png"  data-src="img/5.jpg"  class="lazy"   / alt="純CSS實現手風琴效果範例詳解" >
                    </a>
                    <p class="title">
                        <a href="#">长江.三峡</a>
                    </p>
                </li>
            </ul>
        </p>
</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;
        }

實作效果圖如下:

#滑鼠未移上去時效果

滑鼠移到某張圖片效果

這是一個很簡單的小demo,容易上手,對於初學者來說也不難。同時也透過這個demo感受到了CSS的強大與魅力之處,希望能帶給大家一點小小的幫助。最後梳理一下,做一下這個demo中所用的知識點做一個總結:

1.hover 選擇器

解釋::hover 選擇器用於選擇滑鼠指標浮動在上面的元素。 :hover 選擇器可用於所有元素,不只是連結。

補充::link 選擇器設定指向未被訪問頁面的鏈接的樣式,:visited 選擇器用於設定指向已被訪問的頁面的鏈接,:active 選擇器用於活動鏈接。

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

2.transition屬性

解釋:transition是CSS3一個簡寫屬性,用於設定四個過渡屬性:

  1. transition-property:規定設定過渡效果的CSS 屬性的名稱。

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

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

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

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

相關推薦:

jquery手風琴焦點動畫

jQuery實作簡單的手風琴效果實例程式碼

#利用Bootstrap實現手風琴效果

以上是純CSS實現手風琴效果範例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
錨定位只是不關心來源訂單錨定位只是不關心來源訂單Apr 29, 2025 am 09:37 AM

錨定定位避開HTML源順序的事實是如此之高,因為它在內容和演示文稿之間的另一個關注點是另一個分離的事實。

保證金是什麼:40px 100px 120px 80px表示?保證金是什麼:40px 100px 120px 80px表示?Apr 28, 2025 pm 05:31 PM

文章討論了CSS保證金屬性,特別是“保證金:40px 100px 120px 80px”,其應用程序以及對網頁佈局的影響。

什麼是不同的CSS邊框特性?什麼是不同的CSS邊框特性?Apr 28, 2025 pm 05:30 PM

本文討論了CSS邊境屬性,重點是自定義,最佳實踐和響應能力。主要論點:邊境 - 拉迪烏斯(Border-Radius)對響應式設計最有效。

什麼是CSS背景,列出屬性?什麼是CSS背景,列出屬性?Apr 28, 2025 pm 05:29 PM

本文討論了CSS背景屬性,它們在增強網站設計方面的用途以及避免的常見錯誤。重點是使用背景大小的響應式設計。

什麼是CSS HSL顏色?什麼是CSS HSL顏色?Apr 28, 2025 pm 05:28 PM

文章討論了CSS HSL顏色,其在網絡設計中的使用以及比RGB的優勢。主要重點是通過直觀的顏色操縱來增強設計和可訪問性。

我們如何在CSS中添加評論?我們如何在CSS中添加評論?Apr 28, 2025 pm 05:27 PM

本文討論了CSS中評論的使用,詳細介紹了單線和多行評論語法。它認為註釋可以增強代碼的可讀性,可維護性和協作,但如果無法正確管理,可能會影響網站性能。

什麼是CSS選擇器?什麼是CSS選擇器?Apr 28, 2025 pm 05:26 PM

本文討論了CSS選擇器,其類型和用於造型HTML元素的用法。它比較ID和類選擇器,並與復雜的選擇器解決性能問題。

哪種類型的CSS持有最高優先級?哪種類型的CSS持有最高優先級?Apr 28, 2025 pm 05:25 PM

本文討論了CSS優先級,重點是具有最高特異性的內聯風格。它解釋了特異性級別,覆蓋方法和用於管理CSS衝突的工具。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境