亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

CSS3實現炫酷的切片式圖片輪播效果

2024-07-11 09:00:00
字體:
來源:轉載
供稿:網友

今天我們學習如何使用CSS創建一個炫酷的圖片輪播組件。它的原理簡單的說就是通過單擊標簽元素(label)來切換背景圖像和動畫效果。核心是使用與標簽關聯的單選按鈕和使用通用兄弟選擇器來定位每張圖片。

我們要實現的最終效果是這樣的:

輪播的構成

HTML由三個主要部分組成:單選按鈕和標簽、包含四個面板的容器及其每張圖片的“切片”以及標題。設置為class="cr-bgimg"的容器將為每個圖片劃分四個面板,其中,在每個面板里通過background-position屬性將背景圖片定位在合適的位置上。所以,第一個面板將有四個切片,每個切片都有一個圖片作為背景,并且位于容器最左邊的位置。第二個面板也有四個切片,它位于第一個面板的右側,用于顯示圖片的第二個切片部分:

 

<section class="cr-container">                <!-- 單選按鈕和label標簽 -->    <input id="select-img-1" name="radio-set-1" type="radio" class="cr-selector-img-1" checked/>    <label for="select-img-1" class="cr-label-img-1">1</label>    <input id="select-img-2" name="radio-set-1" type="radio" class="cr-selector-img-2" />    <label for="select-img-2" class="cr-label-img-2">2</label>    <input id="select-img-3" name="radio-set-1" type="radio" class="cr-selector-img-3" />    <label for="select-img-3" class="cr-label-img-3">3</label>    <input id="select-img-4" name="radio-set-1" type="radio" class="cr-selector-img-4" />    <label for="select-img-4" class="cr-label-img-4">4</label>    <div class="clr"></div>        <!-- 面板 -->    <div class="cr-bgimg">        <div>            <span>Slice 1 - Image 1</span>            <span>Slice 1 - Image 2</span>            <span>Slice 1 - Image 3</span>            <span>Slice 1 - Image 4</span>        </div>        <div>            <span>Slice 2 - Image 1</span>            <span>Slice 2 - Image 2</span>            <span>Slice 2 - Image 3</span>            <span>Slice 2 - Image 4</span>        </div>        <div>            <span>Slice 3 - Image 1</span>            <span>Slice 3 - Image 2</span>            <span>Slice 3 - Image 3</span>            <span>Slice 3 - Image 4</span>        </div>        <div>            <span>Slice 4 - Image 1</span>            <span>Slice 4 - Image 2</span>            <span>Slice 4 - Image 3</span>            <span>Slice 4 - Image 4</span>        </div>    </div>    <!-- 標題 -->    <div class="cr-titles">        <h3>            <span>Serendipity</span>            <span>What you've been dreaming of</span>        </h3>        <h3>            <span>Adventure</span>            <span>Where the fun begins</span>        </h3>        <h3>            <span>Nature</span>            <span>Unforgettable eperiences</span>        </h3>        <h3>            <span>Serenity</span>            <span>When silence touches nature</span>        </h3>    </div></section>

h3元素中包含兩個span元素,一個是主標題,一個是子標題。

CSS

為了代碼的簡潔,文章的CSS中都省略了瀏覽器前綴,但是你獲取到的代碼是包含完整的。

我們的第一個目標是實現點擊label元素的時候觸發對應的單選按鈕,方法很簡單,就是將label元素的for屬性值與單選按鈕的ID值對應起來就可以了。

第二步,我們要將所有的背景圖片定位在正確的位置上。第三步,在單擊label標簽時,顯示對應的圖片切片和標題。

我們一步一步看,首先設置最外層section元素的樣式,給它設置一個淡淡的陰影效果。

.cr-container{    width: 600px;    height: 400px;    position: relative;    margin: 0 auto;    border: 20px solid #fff;    box-shadow: 1px 1px 3px rgba(0,0,0,0.1);}

因為后面我們要使用通用兄弟選擇器“~”來選中對應的圖片切片和標題,于是將所有的label元素放在代碼的最上面。通過設置z-index屬性確保label元素顯示在圖片和文字的上面,并且通過margin-top屬性使它們距離整體上邊框350px。

.cr-container label{    font-style: italic;    width: 150px;    height: 30px;    cursor: pointer;    color: #fff;    line-height: 32px;    font-size: 24px;    float:left;    position: relative;    margin-top: 350px;    z-index: 1000;}

接著,添加一個小圓圈來美化label元素,我們創建一個偽元素,并將其放在文字的中心位置。

.cr-container label:before{    content:'';    width: 34px;    height: 34px;    background: rgba(130,195,217,0.9);    position: absolute;    left: 50%;    margin-left: -17px;    border-radius: 50%;    box-shadow: 0px 0px 0px 4px rgba(255,255,255,0.3);    z-index:-1;}

為了在面板與面板之間創建一個分隔線,我們使用label元素的另一個偽元素,并通過漸變背景將它從圖片的上邊緣延伸到下邊緣。

.cr-container label:after{    width: 1px;    height: 400px;    content: '';    background: linear-gradient(top, rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);    position: absolute;    bottom: -20px;    right: 0px;}

最后一個面板的右側不應該有分隔線,所以我們將它的寬度設置為0。

.cr-container label.cr-label-img-4:after{    width: 0px;}

現在,label標簽的樣式就完成了,我們可以將所有的單選按鈕隱藏掉。

.cr-container input{    display: none;}

當我們點擊一個label元素時,它對應的單選按鈕就是被選中。反過來,就可以使用通用兄弟選擇器來選擇選中按鈕對應的label元素,并改變它的文字顏色。

.cr-container input.cr-selector-img-1:checked ~ label.cr-label-img-1,.cr-container input.cr-selector-img-2:checked ~ label.cr-label-img-2,.cr-container input.cr-selector-img-3:checked ~ label.cr-label-img-3,.cr-container input.cr-selector-img-4:checked ~ label.cr-label-img-4{    color: #68abc2;}

我們還可以改變小圓圈的顏色并添加一個陰影效果。

.cr-container input.cr-selector-img-1:checked ~ label.cr-label-img-1:before,.cr-container input.cr-selector-img-2:checked ~ label.cr-label-img-2:before,.cr-container input.cr-selector-img-3:checked ~ label.cr-label-img-3:before,.cr-container input.cr-selector-img-4:checked ~ label.cr-label-img-4:before{    background: #fff;    box-shadow: 0px 0px 0px 4px rgba(104,171,194,0.6);}

圖片的容器將占據所有的寬度,并且絕對定位。稍后使用這個容器將背景圖片設置為當前選定的圖片。我們還需要一張默認可見的圖片,因此,再添加一些背景屬性:

.cr-bgimg{    width: 600px;    height: 400px;    position: absolute;    left: 0px;    top: 0px;    z-index: 1;    background-repeat: no-repeat;    background-position: 0 0;}

因為我們有四個面板,每個面板的寬度為150像素(600除以4)。面板設置為左浮動后會并排顯示,同時設置它們溢出隱藏,因為我們不希望在滑動時看到切片出來:

.cr-bgimg div{    width: 150px;    height: 100%;    position: relative;    float: left;    overflow: hidden;    background-repeat: no-repeat;}

 

每個切片也被設置為絕對定位,并且通過left:-150px將它們顯示在面板的外面并隱藏起來:

.cr-bgimg div span{    position: absolute;    width: 100%;    height: 100%;    top: 0px;    left: -150px;    z-index: 2;    text-indent: -9000px;}

 

再來,讓我們來處理容器和每個切片的背景圖片:

.cr-container input.cr-selector-img-1:checked ~ .cr-bgimg,.cr-bgimg div span:nth-child(1){    background-image: url(../images/1.jpg);}.cr-container input.cr-selector-img-2:checked ~ .cr-bgimg,.cr-bgimg div span:nth-child(2){    background-image: url(../images/2.jpg);}.cr-container input.cr-selector-img-3:checked ~ .cr-bgimg,.cr-bgimg div span:nth-child(3){    background-image: url(../images/3.jpg);}.cr-container input.cr-selector-img-4:checked ~ .cr-bgimg,.cr-bgimg div span:nth-child(4){    background-image: url(../images/4.jpg);}

 

我們還需要根據不同的面板為切片的背景圖片提供不同的定位:

.cr-bgimg div:nth-child(1) span{    background-position: 0px 0px;}.cr-bgimg div:nth-child(2) span{    background-position: -150px 0px;}.cr-bgimg div:nth-child(3) span{    background-position: -300px 0px;}.cr-bgimg div:nth-child(4) span{    background-position: -450px 0px;}

 

當我們單擊一個label標簽時,我們將所有的切片滑到右邊:

.cr-container input:checked ~ .cr-bgimg div span{    animation: slideOut 0.6s ease-in-out;}@keyframes slideOut{    0%{        left: 0px;    }    100%{        left: 150px;    }}

 

但是除了我們選中的這個label標簽,它對應的圖片切片是從-150px滑到0px:

 

.cr-container input.cr-selector-img-1:checked ~ .cr-bgimg div span:nth-child(1),.cr-container input.cr-selector-img-2:checked ~ .cr-bgimg div span:nth-child(2),.cr-container input.cr-selector-img-3:checked ~ .cr-bgimg div span:nth-child(3),.cr-container input.cr-selector-img-4:checked ~ .cr-bgimg div span:nth-child(4){    transition: left 0.5s ease-in-out;    animation: none;    left: 0px;    z-index: 10;}

最后,設置h3標簽中主副標題的樣式,當我們點擊了某個label標簽后,它對應的標題的透明度會從0過渡到1:

 

.cr-titles h3{    position: absolute;    width: 100%;    text-align: center;    top: 50%;    z-index: 10000;    opacity: 0;    color: #fff;    text-shadow: 1px 1px 1px rgba(0,0,0,0.1);    transition: opacity 0.8s ease-in-out;}.cr-titles h3 span:nth-child(1){    font-family: 'BebasNeueRegular', 'Arial Narrow', Arial, sans-serif;    font-size: 70px;    display: block;    letter-spacing: 7px;}.cr-titles h3 span:nth-child(2){    letter-spacing: 0px;    display: block;    background: rgba(104,171,194,0.9);    font-size: 14px;    padding: 10px;    font-style: italic;    font-family: Cambria, Palatino, "Palatino Linotype", "Palatino LT STD", Georgia, serif;}.cr-container input.cr-selector-img-1:checked ~ .cr-titles h3:nth-child(1),.cr-container input.cr-selector-img-2:checked ~ .cr-titles h3:nth-child(2),.cr-container input.cr-selector-img-3:checked ~ .cr-titles h3:nth-child(3),.cr-container input.cr-selector-img-4:checked ~ .cr-titles h3:nth-child(4){    opacity: 1;}

 

就是這樣!切片式的輪播效果就這樣實現了。當然通過這個效果我們還可以延伸出更多的切片效果,例如:

效果二


 

效果三

效果四

總結

以上所述是小編給大家介紹的CSS3實現炫酷的切片式圖片輪播效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品色蜜蜜精品视频在线观看| 日韩欧美极品在线观看| 久久久久久久网站| 欧美精品在线播放| 国产精品视频色| 欧美激情视频在线| 国产做受高潮69| 国内自拍欧美激情| 成人a级免费视频| 成人午夜在线视频一区| 日韩精品极品视频| 成人av在线网址| 亚洲区一区二区| 久久精品这里热有精品| 亚洲国产美女精品久久久久∴| 久久久视频免费观看| 欧美日韩在线看| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美久久久精品| 在线观看日韩专区| 亚洲精品白浆高清久久久久久| 国产精品偷伦一区二区| 国产精品久久久久久久久| 性欧美亚洲xxxx乳在线观看| 亚洲成人av中文字幕| 欧美富婆性猛交| 另类专区欧美制服同性| 色老头一区二区三区| 国产+成+人+亚洲欧洲| 国产精品夫妻激情| 亚洲天堂日韩电影| 久久免费成人精品视频| 亚洲精品一区在线观看香蕉| 亚洲欧美色婷婷| 国产精品高潮粉嫩av| 国产精品1234| 国语自产精品视频在线看一大j8| 亚洲精品网站在线播放gif| 国产精品美女在线观看| 91在线观看免费高清完整版在线观看| 国产成人精品亚洲精品| 亚洲国产精品va在线| 国产精品高清免费在线观看| 亚洲毛片在线免费观看| 96sao精品视频在线观看| 91日本在线视频| 亚洲色图欧美制服丝袜另类第一页| 国产精品久久久久av免费| 久久久久久亚洲| 欧美电影在线观看高清| 欧美老女人在线视频| 久久久中精品2020中文| 亚洲无限av看| 久久精品最新地址| 国产成人精品在线观看| 亚洲第一视频网站| 欧美激情视频网| 中文字幕亚洲综合久久筱田步美| 日韩一区在线视频| 亚洲精品国产综合久久| 欧美最猛性xxxxx亚洲精品| 国产99久久精品一区二区永久免费| 国产一区二区三区视频免费| 最近2019中文字幕第三页视频| 欧美成人免费全部| 日韩电影中文字幕在线观看| 深夜福利一区二区| 日本成人在线视频网址| 国产日韩欧美在线观看| 久久久久久午夜| 成人激情在线观看| 久久久免费电影| 欧美午夜视频在线观看| 亚洲欧美国产精品| 97涩涩爰在线观看亚洲| 国产99久久精品一区二区 夜夜躁日日躁| 亚洲欧美国产高清va在线播| 成人午夜在线视频一区| 国产精品成人va在线观看| 久热爱精品视频线路一| 日韩精品在线观| 国产不卡精品视男人的天堂| 亚洲自拍偷拍色图| 亚洲字幕在线观看| 亚洲天堂影视av| 欧美性视频网站| 菠萝蜜影院一区二区免费| 成人免费高清完整版在线观看| 亚洲综合在线中文字幕| 国产一区二区三区中文| 国产日本欧美视频| 久久精品影视伊人网| 免费成人高清视频| 免费97视频在线精品国自产拍| 亚洲欧美日韩在线一区| 久久久999成人| 91sao在线观看国产| 日韩欧美精品免费在线| 成人伊人精品色xxxx视频| 欧美与欧洲交xxxx免费观看| 久久视频精品在线| 性欧美长视频免费观看不卡| 日韩黄在线观看| 中文欧美在线视频| 欧美午夜激情在线| 国产精品夜色7777狼人| 久久精品最新地址| 日韩在线免费视频观看| 久久久久久久久久久国产| 九色精品免费永久在线| 欧美日韩亚洲精品一区二区三区| 欧美电影免费观看| 亚洲精品在线视频| 91麻豆桃色免费看| 欧美激情性做爰免费视频| 久久视频免费在线播放| 欧美日韩在线第一页| 成人欧美一区二区三区黑人| 亚洲二区中文字幕| 亚洲男人7777| 高清欧美性猛交| 亚洲伊人一本大道中文字幕| 欧美日韩亚洲一区二区| 福利二区91精品bt7086| 成人h片在线播放免费网站| 日韩国产精品一区| 亚洲精品女av网站| 欧美最猛性xxxx| 亚洲欧美在线第一页| 欧美美最猛性xxxxxx| 亚洲免费小视频| 在线播放国产一区中文字幕剧情欧美| 国产偷亚洲偷欧美偷精品| 亚洲精品自拍视频| 亚洲va欧美va在线观看| 亚洲国产精品专区久久| 精品视频偷偷看在线观看| 日韩在线观看视频免费| 性色av一区二区三区红粉影视| 主播福利视频一区| 国产精品99一区| 国产精品一区二区3区| 色与欲影视天天看综合网| 国产精品69精品一区二区三区| 日韩毛片中文字幕| 亚洲午夜色婷婷在线| 国产视频精品免费播放| 国产精品吊钟奶在线| 人体精品一二三区| 国产精品第七十二页| 日韩中文字幕在线观看| 国产精品视频白浆免费视频| 97在线观看免费| 国产精品扒开腿做爽爽爽的视频| 91精品91久久久久久| 亚洲图片在线综合| 日本韩国欧美精品大片卡二| 欧美在线一级va免费观看| 日韩精品电影网| 97碰碰碰免费色视频| 国产精品一区二区av影院萌芽| 国产成人短视频| 久久精品人人爽| 国产精品6699|