溫馨提示×

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

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

HTML+CSS+JS如何實(shí)現(xiàn)堆疊輪播效果

發(fā)布時(shí)間:2021-03-17 12:37:29 來源:億速云 閱讀:346 作者:清風(fēng) 欄目:web開發(fā)

這篇“HTML+CSS+JS如何實(shí)現(xiàn)堆疊輪播效果”文章,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要參考一下,對(duì)于“HTML+CSS+JS如何實(shí)現(xiàn)堆疊輪播效果”,小編整理了以下知識(shí)點(diǎn),請(qǐng)大家跟著小編的步伐一步一步的慢慢理解,接下來就讓我們進(jìn)入主題吧。

效果:
輪播圖在向一個(gè)方向移動(dòng)的同時(shí),要對(duì)其每一個(gè)圖片的大小,位置,透明度以及層級(jí)進(jìn)行改變
原理:
輪播圖向左移動(dòng)時(shí)將第一個(gè)子元素剪切到末尾,輪播圖向右移動(dòng)時(shí),將末尾子元素剪切到最前面,以此實(shí)現(xiàn)無縫輪播效果,再因?yàn)閘i剪切后,下一個(gè)li會(huì)補(bǔ)上(例如第一個(gè)子元素被剪切到最后時(shí),第二個(gè)字元素會(huì)補(bǔ)上成為第一個(gè)子元素),所以li下標(biāo)不變,以次來修改每一個(gè)位置的li的屬性(大小,位置,透明度,層級(jí))
HTML代碼:

 <body>
    <div class="smallBox">
    <div class="arrowLeft">&larr;</div>
    <div class="smallPicBox">            //用一個(gè)div存放一個(gè)ul,并對(duì)ul里的每一個(gè)li進(jìn)行初始樣式設(shè)置
    <ul>
                <li id="li1" style="position: absolute;top:calc(50% - 200px);left: 0px;z-index:1;background-color: aqua;transform: scale(0.5);transition: 0.3s;opacity: 0.5;background-image: url(./images/01.jpg);background-size: cover;"></li>
                <li id="li2" style="position: absolute;top:calc(50% - 200px);left: 150px; z-index:2;background-color: red;transform: scale(0.7); transition: 0.3s;opacity: 0.7;background-image: url(./images/02.jpg);background-size: cover;"></li>
                <li id="li3" style="position: absolute;top:calc(50% - 200px);left: 300px; z-index:3;background-color: blue;transform: scale(0.9); transition: 0.3s;opacity: 0.9;background-image: url(./images/03.jpg);background-size: cover;"></li>
                <li id="li4" style="position: absolute;top:calc(50% - 200px);left: 450px; z-index:4;background-color: green;transform: scale(1); transition: 0.3s;opacity: 1;background-image: url(./images/04.jpg);background-size: cover;"></li>
                <li id="li5" style="position: absolute;top:calc(50% - 200px);left: 600px; z-index:3;background-color: yellow;transform: scale(0.9); transition: 0.3s;opacity: 0.9;background-image: url(./images/05.jpg);background-size: cover;"></li>
                <li id="li6" style="position: absolute;top:calc(50% - 200px);left: 750px; z-index:2;background-color: gray;transform: scale(0.7); transition: 0.3s;opacity: 0.7;background-image: url(./images/06.jpg);background-size: cover;"></li>
                <li id="li7" style="position: absolute;top:calc(50% - 200px);left: 900px; z-index:1;background-color: deeppink;transform: scale(0.5); transition: 0.3s;opacity: 0.5;background-image: url(./images/07.jpg);background-size: cover;"></li>
            </ul>
        </div>
        <div class="arrowRight">&rarr;</div>
    </div>
</div>
</body>

CSS代碼:

<style>
        *{
            margin: 0;
            padding: 0;
            list-style: none;
        }
        .albumBox{
            width: 1200px;
            height: 400px;
            margin: 0 auto;
            border: 1px solid #000;
        }

        .smallBox{
            height: 400px;
            line-height: 400px;
            position: relative;
        }
        .smallPicBox{
            width: 1100px;
            height: 400px;
            float: left;
            position: relative;
        }
        .smallPicBox ul{
            width: 100%;
            height: 400px;
        }
        .smallPicBox li{
            width: 320px;
            height: 400px;
            float: left;
            border: 1px solid #000;
            box-sizing: border-box;
        }
        .smallBox .current::after{
            content: "\25b2";
            position: absolute;
            top: -31px;
            left: 70px;
            color: red;

        }
        .arrowLeft{
            width: 50px;
            height: 400px;
            position: absolute;
            left: 0;
            border: 1px solid #000;
            box-sizing: border-box;
            background-color: gray;
            z-index: 10;
        }
        .arrowRight{
            width: 50px;
            height: 400px;
            position: absolute;
            right: 0;
            border: 1px solid #000;
            box-sizing: border-box;
            background-color: gray;
            z-index: 10;
        }
    </style>

JS代碼:

<script>
        var arrowLeft=document.querySelector(".arrowLeft")
        var arrowRight=document.querySelector(".arrowRight")
        var ul=document.querySelector(".smallPicBox ul")
        var li=document.querySelectorAll(".smallPicBox li")
        var timerId=0
        arrowLeft.onclick=function(){                      //左箭頭點(diǎn)擊事件
                li=document.getElementsByTagName('li')
                ul.appendChild(li[0])                         //將ul的第0個(gè)子元素剪切到末尾,實(shí)現(xiàn)無縫輪播
                 posi(li)                                 //修改每一個(gè)li的屬性
           }
        arrowRight.onclick=function(){                    //右箭頭點(diǎn)擊事件
            li=document.getElementsByTagName('li')        //重新獲取li
                ul.insertBefore(li[6],li[0])                 //將ul的最后一個(gè)子元素剪切到最前面,實(shí)現(xiàn)無縫輪播
                 posi(li)                                 //修改每一個(gè)li的屬性
        }
        
        function posi(li){                                //修改li屬性函數(shù)
            var n1=0
                for(var x=0;x<li.length;x++){     //修改位置
                    li[x].style.left=n1+'px'
                    n1=n1+150
                }
                for(var i=0;i<li.length/2;i++){     //修改層級(jí)
                    li[i].style.zIndex=i+1
                    li[li.length-1-i].style.zIndex=i+1
                }
                li[3].style.zIndex='4'
                var n2=0.3
                for(var j=0;j<li.length/2;j++){        //縮放
                    n2=parseFloat(n2+0.2)
                    li[j].style.transform='scale('+n2+')'
                    li[li.length-1-j].style.transform='scale('+n2+')'
                }
                li[3].style.transform='scale(1)'
                var n3=0.3
                for(var k=0;k<li.length/2;k++){       //修改透明度
                    n3=parseFloat(n3+0.2)
                    li[k].style.opacity=n3
                    li[li.length-1-k].style.opacity=n3
                }
                li[3].style.opacity='1'
        }
        //鼠標(biāo)移入移出
        temerId=setInterval(function(){
             arrowLeft.click()
        }, 1000);
        arrowLeft.onmouseover=function(){
            clearInterval(temerId)
        }
        arrowLeft.onmouseout=function(){
           temerId=setInterval(function(){
            arrowLeft.click()
         }, 1000);
        }
        arrowRight.onmouseover=function(){
            clearInterval(temerId)
        }
        arrowRight.onmouseout=function(){
           temerId=setInterval(function(){
            arrowLeft.click()
         }, 1000);
        }
    </script>

注:本例js是直接寫在body里的,也可以單獨(dú)寫一個(gè)js文件,在引入到html界面

效果圖:
 

HTML+CSS+JS如何實(shí)現(xiàn)堆疊輪播效果

以上是“HTML+CSS+JS如何實(shí)現(xiàn)堆疊輪播效果”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

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

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

AI