成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

CSS3實(shí)現(xiàn)炫酷的切片式圖片輪播效果

jackzou / 3009人閱讀

摘要:今天我們學(xué)習(xí)如何使用創(chuàng)建一個(gè)炫酷的圖片輪播組件。我們還可以改變小圓圈的顏色并添加一個(gè)陰影效果。圖片的容器將占據(jù)所有的寬度,并且絕對(duì)定位。當(dāng)然通過這個(gè)效果我們還可以延伸出更多的切片效果,例如效果二效果三效果四要獲取以上輪播效果的代碼可以

今天我們學(xué)習(xí)如何使用CSS創(chuàng)建一個(gè)炫酷的圖片輪播組件。它的原理簡單的說就是通過單擊標(biāo)簽元素(label)來切換背景圖像和動(dòng)畫效果。核心是使用與標(biāo)簽關(guān)聯(lián)的單選按鈕和使用通用兄弟選擇器來定位每張圖片。

我們要實(shí)現(xiàn)的最終效果是這樣的:

輪播的構(gòu)成

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

Slice 1 - Image 1 Slice 1 - Image 2 Slice 1 - Image 3 Slice 1 - Image 4
Slice 2 - Image 1 Slice 2 - Image 2 Slice 2 - Image 3 Slice 2 - Image 4
Slice 3 - Image 1 Slice 3 - Image 2 Slice 3 - Image 3 Slice 3 - Image 4
Slice 4 - Image 1 Slice 4 - Image 2 Slice 4 - Image 3 Slice 4 - Image 4

Serendipity What you"ve been dreaming of

Adventure Where the fun begins

Nature Unforgettable eperiences

Serenity When silence touches nature

h3元素中包含兩個(gè)span元素,一個(gè)是主標(biāo)題,一個(gè)是子標(biāo)題。

CSS

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

我們的第一個(gè)目標(biāo)是實(shí)現(xiàn)點(diǎn)擊label元素的時(shí)候觸發(fā)對(duì)應(yīng)的單選按鈕,方法很簡單,就是將label元素的for屬性值與單選按鈕的ID值對(duì)應(yīng)起來就可以了。

第二步,我們要將所有的背景圖片定位在正確的位置上。第三步,在單擊label標(biāo)簽時(shí),顯示對(duì)應(yīng)的圖片切片和標(biāo)題。

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

.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);
}

因?yàn)楹竺嫖覀円褂猛ㄓ眯值苓x擇器“~”來選中對(duì)應(yīng)的圖片切片和標(biāo)題,于是將所有的label元素放在代碼的最上面。通過設(shè)置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;
}

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

.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;
}

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

.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;
}

最后一個(gè)面板的右側(cè)不應(yīng)該有分隔線,所以我們將它的寬度設(shè)置為0。

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

現(xiàn)在,label標(biāo)簽的樣式就完成了,我們可以將所有的單選按鈕隱藏掉。

.cr-container input{
    display: none;
}

當(dāng)我們點(diǎn)擊一個(gè)label元素時(shí),它對(duì)應(yīng)的單選按鈕就是被選中。反過來,就可以使用通用兄弟選擇器來選擇選中按鈕對(duì)應(yīng)的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;
}

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

.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);
}

圖片的容器將占據(jù)所有的寬度,并且絕對(duì)定位。稍后使用這個(gè)容器將背景圖片設(shè)置為當(dāng)前選定的圖片。我們還需要一張默認(rèn)可見的圖片,因此,再添加一些背景屬性:

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

因?yàn)槲覀冇兴膫€(gè)面板,每個(gè)面板的寬度為150像素(600除以4)。面板設(shè)置為左浮動(dòng)后會(huì)并排顯示,同時(shí)設(shè)置它們溢出隱藏,因?yàn)槲覀儾幌M诨瑒?dòng)時(shí)看到切片出來:

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

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

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

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

.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);
}

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

.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;
}

當(dāng)我們單擊一個(gè)label標(biāo)簽時(shí),我們將所有的切片滑到右邊:

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

但是除了我們選中的這個(gè)label標(biāo)簽,它對(duì)應(yīng)的圖片切片是從-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;
}

最后,設(shè)置h3標(biāo)簽中主副標(biāo)題的樣式,當(dāng)我們點(diǎn)擊了某個(gè)label標(biāo)簽后,它對(duì)應(yīng)的標(biāo)題的透明度會(huì)從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;
}

就是這樣!切片式的輪播效果就這樣實(shí)現(xiàn)了。當(dāng)然通過這個(gè)效果我們還可以延伸出更多的切片效果,例如:

效果二

效果三

效果四

要獲取以上輪播效果的代碼可以:

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/114704.html

相關(guān)文章

  • CSS3實(shí)現(xiàn)炫酷的切片式圖片輪播效果

    摘要:今天我們學(xué)習(xí)如何使用創(chuàng)建一個(gè)炫酷的圖片輪播組件。我們還可以改變小圓圈的顏色并添加一個(gè)陰影效果。圖片的容器將占據(jù)所有的寬度,并且絕對(duì)定位。當(dāng)然通過這個(gè)效果我們還可以延伸出更多的切片效果,例如效果二效果三效果四要獲取以上輪播效果的代碼可以 今天我們學(xué)習(xí)如何使用CSS創(chuàng)建一個(gè)炫酷的圖片輪播組件。它的原理簡單的說就是通過單擊標(biāo)簽元素(label)來切換背景圖像和動(dòng)畫效果。核心是使用與標(biāo)簽關(guān)聯(lián)的...

    EdwardUp 評(píng)論0 收藏0
  • CSS3實(shí)現(xiàn)炫酷的切片式圖片輪播效果

    摘要:今天我們學(xué)習(xí)如何使用創(chuàng)建一個(gè)炫酷的圖片輪播組件。我們還可以改變小圓圈的顏色并添加一個(gè)陰影效果。圖片的容器將占據(jù)所有的寬度,并且絕對(duì)定位。當(dāng)然通過這個(gè)效果我們還可以延伸出更多的切片效果,例如效果二效果三效果四要獲取以上輪播效果的代碼可以 今天我們學(xué)習(xí)如何使用CSS創(chuàng)建一個(gè)炫酷的圖片輪播組件。它的原理簡單的說就是通過單擊標(biāo)簽元素(label)來切換背景圖像和動(dòng)畫效果。核心是使用與標(biāo)簽關(guān)聯(lián)的...

    molyzzx 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

jackzou

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<