中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript是怎樣實現網頁輪播圖

發布時間:2021-12-27 10:01:56 來源:億速云 閱讀:138 作者:柒染 欄目:開發技術

這篇文章將為大家詳細講解有關JavaScript是怎樣實現網頁輪播圖,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

    前言:

            在網頁中,我們經常會看到各種輪播圖的效果,它們到底是怎樣實現的呢?今天,我們就一起來看一下!首先,我們需要準備若干張圖片,在這里我準備了五張圖片。

    功能需求:

    • 鼠標經過輪播圖模塊,左右按鈕顯示,離開隱藏左右按鈕。

    • 點擊右側按鈕一次,圖片往左播放一張,以此類推, 左側按鈕同理。

    • 圖片播放的同時,下面小圓圈模塊跟隨一起變化。

    • 點擊小圓圈,可以播放相應圖片。

    • 鼠標不經過輪播圖, 輪播圖也會自動播放圖片。

    • 鼠標經過,輪播圖模塊, 自動播放停止。

    我們頁面布局如下所示:

    JavaScript是怎樣實現網頁輪播圖

    接下來就一步步的實現功能

    創建HTML頁面

           實現流程是:先給定一個大盒子,為了方便后面盒子的定位操作,再給它一個相對定位,把圖片通過無序列表的形式添加進大盒子中,因為我們要實現的輪播圖效果是橫向的,所以我們可以給圖片添加float:left屬性,又因為圖片所在的ul不夠大,所以其他的圖片會被擠到下面,所以我們可以手動修改圖片所在的ul的大小;接下來寫一個無序列表用于放置小圓圈,通過絕對定位的方式將其定位到大盒子的下面,在將小圓圈加進去,方便我們實現點擊對應的小圓圈,就跳轉到相應圖片的效果。然后將左右箭頭通過絕對定位分別定到大盒子兩側合適位置。最后,我們再將大盒子外面的內容隱藏掉。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta http-equiv="X-UA-Compatible" content="IE=edge">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <title>Document</title>
        <link rel="stylesheet" href="index.css" rel="external nofollow" >
    </head>
    <body>
        <div class="box">
            <a href="" class = 'left jiantou'>&lt;</a>
            <a href="" class = 'right jiantou'>&gt;</a>
            <ul class = 'pic'>
                <li>
                    <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img src="./images/1.jpg" alt=""></a>
                </li>
                <li>
                    <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img src="./images/2.jpg" alt=""></a>
                </li>
                <li>
                    <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img src="./images/3.jpg" alt=""></a>
                </li>
                <li>
                    <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img src="./images/4.jpg" alt=""></a>
                </li>
                 <li>
                    <a href="#" rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow"  rel="external nofollow" ><img src="./images/5.jpg" alt=""></a>
                </li>
            </ul>
            <ul class="lis">
                <li></li>
                <li class = 'selected'></li>
                <li></li>
                <li></li>
                <li></li>
            </ul>
        </div>
    </body>
    </html>

    css文件

    *{
        margin: 0;
        padding: 0;
    }
    li{
        list-style: none;
    }
    .box{
        position: relative;
        overflow: hidden;
        margin: 100px auto;
        width: 520px;
        height: 280px;
        background-color: red;
    }
    .jiantou{
        font-size: 24px;
        text-decoration: none;
        display: block;
        text-align: center;
        width: 20px;
        height: 30px;
        line-height: 30px;
        background: rgba(158, 154, 154, 0.7);
        color: white;
        z-index: 999;
    }
    .left{
        position: absolute;
        top: 125px;
        left: 0px;
        border-top-right-radius: 15px;
        border-bottom-right-radius: 15px;
    }
    .right{
        position: absolute;
        top:125px;
        left: 500px;
        border-top-left-radius: 15px;
        border-bottom-left-radius: 15px;
    }
    img{
        width: 520px;
        height: 280px;
    }
    .box .pic{
        width: 600%;
    }
    .pic li {
        float: left;
    }
    .lis{
       position: absolute;
       bottom: 15px;
       left: 50%;
       margin-left: -35px;
       width: 70px;
       height:13px;
       border-radius: 7px; 
       background: rgba(158, 154, 154, 0.7);
    }
    .lis li {
        float: left;
        width: 8px;
        height: 8px;
        margin: 3px;
        border-radius: 50%;
        background-color: #fff;
       
    }
    .lis .selected{
        background-color: cyan;
    }

    此時頁面效果為:

    JavaScript是怎樣實現網頁輪播圖

    實現js部分的功能

    1、左右按鈕

    當鼠標經過輪播圖模塊,左右按鈕顯示,離開隱藏左右按鈕。

           首先,我們先通過display:none讓我們初始的兩個箭頭隱藏;然后獲取兩個箭頭和大盒子,在給大盒子添加鼠標經過和鼠標離開事件。

    如下所示:

     var left = document.querySelector('.left');
        var right = document.querySelector('.right');
        var box = document.querySelector('.box');
        box.addEventListener('mouseenter',function(){
            left.style.display = 'block';
            right.style.display = 'block';
        })
        box.addEventListener('mouseleave',function(){
            left.style.display = 'none';
            right.style.display = 'none';
        })

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    2、動態生成小圓圈

            先刪除掉所有的小圓圈的li,如圖所示:

    JavaScript是怎樣實現網頁輪播圖

            因為我們創建的小圓圈是根據圖片的張數決定的,所以我們的核心思路就是:小圓圈的個數要跟圖片張數一致,先得到ul里面圖片的張數(圖片放入li里面,所以就是li的個數),然后利用循環動態通過創建節點createElement(‘li')和插入節點 ul. appendChild(li)生成小圓圈(這個小圓圈要放入ul里面)要注意第一個小圓圈需要添加selected類。

    實現代碼為:

    var pic = document.querySelector('.pic');
        var lis = document.querySelector('.lis');
        for(var i = 0;i<pic.children.length;i++){
            var li = document.createElement('li');
            lis.appendChild(li);
        }
        lis.children[0].className = 'selected';

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    3、點擊小圓圈,小圓圈變色

            在生成小li的同時,根據排他思想,給小圓圈添加點擊事件,當點擊對應的小圓圈時,讓其添加selected類,其余的小圓圈刪除selected類。

    代碼為:

    li.addEventListener('click',function(){
                for(var i =0;i<lis.children.length;i++){
                    lis.childern[i].className = '';
                }
                this.className = 'selected';
            })

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    4、點擊小圓圈滾動圖片

            這里就用到動畫函數,前面已經講過怎樣封裝動畫函數,這里不在贅述,直接引用。但是要注意將動畫函數的js文件放在我們index.js的上面。又因為只有添加了定位了元素才可以使用動畫函數,我們還需要給pic這個ul添加定位。然后根據規律發現: 點擊某個小圓圈 ,ul滾動的距離為: 小圓圈的索引號乘以圖片的寬度。(因為圖片是向左走,所以為負值)所以需要知道小圓圈的索引號, 我們就可以在生成小圓圈的時候,給它設置一個自定義屬性,點擊的時候獲取這個自定義屬性。

    先在生成li的時候設置索引:

    li.setAttribute('index',i);

            然后在給li添加點擊事件的時候獲得索引,并得到圖片寬度,調用動畫函數:

    li.addEventListener('click',function(){
        var boxWidth = box.offsetWidth;
        //獲得索引號
        var index = this.getAttribute('index');
        for(var i = 0;i<lis.children.length;i++){
            lis.children[i].className = '';
        }
        this.className = 'selected';
        animate(pic,-index*boxWidth)
    })

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    5、點擊右側按鈕一次,就讓圖片滾動一張。

            可以直接給右側按鈕添加點擊事件,聲明一個變量num, 點擊一次,自增1, 讓這個變量乘以圖片寬度,就是 ul 的滾動距離。

    var num = 0;
        right.addEventListener('click',function(){
            num++;
            animate(pic,-num*boxWidth);
        })

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

            我們發現,當點擊右側按鈕時,可以實現圖片的切換效果,但是當點擊到最后一張圖片的時候,就會停留在顯頁面初始背景,并不美觀,所以我們就可以通過圖片無縫滾動原理讓圖片無縫滾動,操作方法為。將.pic列表里的第一個li通過cloneNode(true)添加一份,然后通過appendChild()復制到該列表的末尾,然后再在js頁面中給num添加一個判斷條件,即當num的值等于這個列表里面元素的個數-1的時候,讓ul移動的距離變為0,并讓num等于0。

    代碼為:

    var first = pic.children[0].cloneNode(true);
        pic.appendChild(first);
        //右側按鈕的功能
        var num = 0;
        right.addEventListener('click',function(){
            if(num == pic.children.length-1){
                pic.style.left = 0;
                num = 0;
            }
            num++;
            animate(pic,-num*boxWidth);
        })

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    成功實現。

    6、點擊右側按鈕, 小圓圈跟隨變化

            需要進行的操作是:再聲明一個變量circle,每次點擊右側按鈕時自增1,因為當我們左側按鈕點擊時也會實現該效果,也需要這個變量,因此要聲明全局變量。但是圖片有5張,我們小圓圈只有4個少一個,必須加一個判斷條件,如果circle == 4就 從新復原為 0。

     var num = 0;
    var circle = 0;
      right.addEventListener('click',function(){
          if(num == pic.children.length-1){
              pic.style.left = 0;
              num = 0;
          }
          num++;
          animate(pic,-num*boxWidth);
          circle++;
          if(circle == lis.children.length){
              circle = 0;
          }
          for(var i =0;i<lis.children.length;i++){
              lis.children[i].className = '';
          }
          lis.children[circle].className = 'selected';
      })

    運行結果為:

    JavaScript是怎樣實現網頁輪播圖

            但是這樣還是有點小問題的,當我們讓小圓圈和右側按鈕結合起來使用的時候,就會發現錯誤,如下:

    JavaScript是怎樣實現網頁輪播圖

            當我們點擊小圓點時,也可以跳轉到相應的圖片頁,但當我們繼續點擊右側按鈕時,就會發現下面的小圓點和對應的圖片不對應了。這是我們我們的右側按鈕點擊事件時通過變量num來控制的,而num變量和小圓圈的點擊事件沒有任何關系,所以就存在差異。
    我們的解決方案就是每次點擊小li時,獲得它的索引號,然后把numcircle的值改為得到的索引號的值,代碼為:

    var index = this.getAttribute('index');
    num = index;
    circle = index;

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    7、左側按鈕功能制作

    和右側按鈕做法類似,不在贅述,代碼如下:

    left.addEventListener('click',function(){
            if(num == 0){
                num = pic.children.length-1;
                pic.style.left = -num*boxWidth+'px';
                
            }
            num--;
            animate(pic,-num*boxWidth);
            circle--;
            if(circle <0){
                circle = lis.children.length-1;
            }
            for(var i =0;i<lis.children.length;i++){
                lis.children[i].className = '';
            }
            lis.children[circle].className = 'selected';
        })

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    8、自動播放功能

            其實添加一個定時器自動播放輪播圖,就類似于點擊了右側按鈕,此時我們使用手動調用右側按鈕點擊事件 right.click(),鼠標經過圖片就停止定時器 ,鼠標離開圖片就開啟定時器。

    var timer = this.setInterval(function(){
      right.click();
     },2000)

    實現效果為:

    JavaScript是怎樣實現網頁輪播圖

    完整index.js的代碼為:

    window.addEventListener('load',function(){
        var left = document.querySelector('.left');
        var right = document.querySelector('.right');
        var box = document.querySelector('.box');
        box.addEventListener('mouseenter',function(){
            left.style.display = 'block';
            right.style.display = 'block';
        })
        box.addEventListener('mouseleave',function(){
            left.style.display = 'none';
            right.style.display = 'none';
        })
        var pic = document.querySelector('.pic');
        var lis = document.querySelector('.lis');
        var boxWidth = box.offsetWidth;
        for(var i = 0;i<pic.children.length;i++){
            
            var li = document.createElement('li');
            lis.appendChild(li);
            //設置索引號
            li.setAttribute('index',i);
            li.addEventListener('click',function(){
                //獲得索引號
                var index = this.getAttribute('index');
                num = index;
                circle = index;
                for(var i = 0;i<lis.children.length;i++){
                    lis.children[i].className = '';
                }
                this.className = 'selected';
                animate(pic,-index*boxWidth)
            })
        }
        lis.children[0].className = 'selected';
        //克隆第一個li
        var first = pic.children[0].cloneNode(true);
        pic.appendChild(first);
        var num = 0;
        var circle = 0;
        //右側按鈕的功能
        right.addEventListener('click',function(){
            if(num == pic.children.length-1){
                pic.style.left = 0;
                num = 0;
            }
            num++;
            animate(pic,-num*boxWidth);
            circle++;
            if(circle == lis.children.length){
                circle = 0;
            }
            for(var i =0;i<lis.children.length;i++){
                lis.children[i].className = '';
            }
            lis.children[circle].className = 'selected';
        })
        //左側按鈕功能
        left.addEventListener('click',function(){
            if(num == 0){
                num = pic.children.length-1;
                pic.style.left = -num*boxWidth+'px';
                
            }
            num--;
            animate(pic,-num*boxWidth);
            circle--;
            if(circle <0){
                circle = lis.children.length-1;
            }
            for(var i =0;i<lis.children.length;i++){
                lis.children[i].className = '';
            }
            lis.children[circle].className = 'selected';
        })
        var timer = this.setInterval(function(){
            right.click();
        },2000)
    })

    關于JavaScript是怎樣實現網頁輪播圖就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    镇宁| 富锦市| 正宁县| 定州市| 太白县| 福清市| 鹤峰县| 乌苏市| 永川市| 大洼县| 德江县| 普兰店市| 若羌县| 胶南市| 和静县| 赣州市| 辉南县| 射洪县| 乐都县| 姜堰市| 犍为县| 岑溪市| 军事| 介休市| 大连市| 沭阳县| 上犹县| 庆安县| 梅河口市| 克东县| 吉林省| 永嘉县| 山东| 建始县| 宁晋县| 门头沟区| 独山县| 河南省| 辽源市| 桐梓县| 斗六市|