您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關怎么利用CSS實現圖片輪播效果的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
理論基礎
CSS3 animation 屬性和 @keyframes 規則
主體思想
準備相同大小的多個圖片
將要展示圖片橫排放在一個圖片容器里面
在圖片容器外再加一個展示容器,展示容器大小為圖片大小
給圖片容器添加自定義動畫,在動畫不同階段設置遞增的偏移值
注意事項
動畫效果分為切換和停留兩部分
自定義動畫階段與圖片數量相關
動畫各階段偏移值與圖片大小相關
本文中示例最后一個圖片到第一個圖片沒有切換效果,一個思路是可以由最后一個圖片再挨個切換到第一個圖片
HTML
<div id="container"> <div id="photo"> <img src="1.png" /> <img src="2.png" /> <img src="3.png" /> </div> </div>
解析:
這里創建了三個 img 元素,img 元素外面是圖片容器,圖片容器外面是展示容器。
CSS
#container { width: 400px; height: 300px; overflow: hidden; } #photo { width: 1200px; animation: switch 5s ease-out infinite; } #photo > img { float: left; width: 400px; height: 300px; } @keyframes switch { 0%, 25% { margin-left: 0; } 35%, 60% { margin-left: -400px; } 70%, 100% { margin-left: -800px; } }
解析:
展示容器大小和圖片大小一致
圖片添加 float 效果,不用考慮麻煩的 margin 問題
由于示例只有三個圖片,所以添加了三個動畫階段,每一階段都是通過設置遞增的 margin-left 值達到切換的效果
設置的動畫階段(如:35%~60%)是動畫停留部分,和上一階段空余時間(如25%~35%)即為動畫切換部分,各部分時間長短需要自己把控
運行效果
感謝各位的閱讀!關于“怎么利用CSS實現圖片輪播效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。