欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

如何用原生javascript實(shí)現(xiàn)輪播圖

這篇文章主要介紹了如何用原生javascript實(shí)現(xiàn)輪播圖,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

10年積累的網(wǎng)站制作、網(wǎng)站設(shè)計(jì)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有山陰免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

使用原生js實(shí)現(xiàn)輪播圖

使用原生JS實(shí)現(xiàn)輪播圖的案例,靜態(tài)效果圖如下:
如何用原生javascript實(shí)現(xiàn)輪播圖

核心思想

將一些圖片在一行中平鋪,然后計(jì)算偏移量再利用定時(shí)器實(shí)現(xiàn)定時(shí)輪播。

步驟:

1. 首先搭建基本的HTML結(jié)構(gòu)

<!-- 結(jié)構(gòu)部分 --><!-- 結(jié)構(gòu)說明:外層一個(gè)container盒子,用于放圖片盒子(imgBox)、左箭頭、右箭頭、底部小圓圈, 
        圖片盒子中放的是輪播的圖片 -->
    <p class="container">
      <!-- 注意:此處強(qiáng)調(diào)一下,圖片盒子imgBox的left屬性必須寫成行內(nèi)樣式,否則js中拿不到left的值 -->
        <p class="imgBox" style="left: -500px;"> 
            <img src="./images/lunbo1.jpg" alt="輪播圖1">
            <img src="./images/lunbo2.jpg" alt="輪播圖2">
            <img src="./images/lunbo3.jpg" alt="輪播圖3">
            <img src="./images/lunbo4.jpg" alt="輪播圖4">
            <img src="./images/lunbo5.jpg" alt="輪播圖5">
        </p>

        <a href="javascript:;" class="leftArrow"  style="display: none;">
            <img src="./images/leftArrow.png" alt="左箭頭">
        </a>
        <a href="javascript:;" class="rightArrow"  style="display: none;">
            <img src="./images/rightArrow.png" alt="右箭頭">
        </a>

        <ul class="circleFather">
            <li class="select"></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </p>

2. 樣式部分

使用絕對(duì)定位把左右箭頭和底部小圓圈放在合適的位置。外層容器盒子的寬度等于一張圖片的寬度,圖片盒子的寬度為所有圖片寬度之和,所有圖片左浮動(dòng),實(shí)現(xiàn)水平排列。

☆☆☆注意:此處強(qiáng)調(diào)一下,圖片盒子imgBox的left屬性必須寫成行內(nèi)樣式,否則js中拿不到left的值

 <style>
        /* 內(nèi)聯(lián)樣式表 */
        
        * {
            margin: 0;
            padding: 0;
        }
        
        li {
            list-style: none;
        }
        /* 外層容器樣式 */
        
        .container {
            height: 330px;
            width: 500px;  //外層容器盒子的寬度等于一張圖片的寬度
            margin: 100px auto;
            position: relative;
            overflow: hidden;  //超出隱藏
        } 
        /* 左右箭頭樣式 */
        
        .container .leftArrow,
        .container .rightArrow {
            position: absolute;
            top: 50%;
            transform: translate(0, -50%);
            z-index: 1;
        }
        
        .container .leftArrow {
            left: 5px;
        }
        
        .container .rightArrow {
            right: 5px;
        }
        /* 圖片盒子樣式 */
        
        .imgBox {
            position: absolute;
            transition: all 0.5s;
            height: 333px;
            width: 3500px;  //圖片盒子的寬度為所有圖片寬度之和
        }
        
        .imgBox img {
            height: 330px;
            width: 500px;
            float: left;  //所有圖片左浮動(dòng),實(shí)現(xiàn)水平排列
        }
        /* 底部小圓圈樣式 */
        
        .circleFather {
            position: absolute;
            bottom: 10px;
            left: 50%;
            transform: translate(-50%, 0);
        }
        
        .circleFather li {
            float: left;
            height: 10px;
            width: 10px;
            margin: 0 5px;
            border: 2px solid #e7641c;
            border-radius: 50%;
        }
        
        .select {
            background-color: #e7641c;
        }
    </style>

3. js邏輯部分

3.1 首先實(shí)現(xiàn)點(diǎn)擊左右箭頭向左右滑動(dòng)的功能

var container = document.querySelector('.container') //獲取外層容器盒子
        var imgBox = document.querySelector('.imgBox') //獲取圖片盒子
        var leftArrow = document.querySelector('.leftArrow') //獲取左箭頭
        var rightArrow = document.querySelector('.rightArrow') //獲取右箭頭


        //給左箭頭綁定點(diǎn)擊事件
        leftArrow.onclick = function() {
            goLast()
        }

        //右箭頭點(diǎn)擊事件
        rightArrow.onclick = function() {
            goNext()
        }

        // 顯示上一張圖片
        // 1.點(diǎn)一次左箭頭,就讓left值-500,點(diǎn)一次右箭頭,就讓left值+500
        // 2.但是有兩種特殊情況,(1)當(dāng)前展示圖片1時(shí),點(diǎn)擊左箭頭則需展示圖片5,(2)當(dāng)前展示圖片5時(shí),點(diǎn)擊右箭頭則需展示圖片1
        function goLast() {
            let newBoxLeft            if (imgBox.style.left === '0px') {
                newBoxLeft = -2000
            } else {
                // imgBox.style.left是一個(gè)字符串,所以要轉(zhuǎn)化為數(shù)字才能進(jìn)行計(jì)算,而設(shè)定left時(shí)就要加上px成為一個(gè)字符串
                newBoxLeft = parseInt(imgBox.style.left) + 500;
            }
            imgBox.style.left = newBoxLeft + "px"
        }

        // 顯示下一張圖片
        function goNext() {
            let newBoxLeft            if (imgBox.style.left === '-2000px') {
                newBoxLeft = 0
            } else {
                newBoxLeft = parseInt(imgBox.style.left) - 500;
            }
            imgBox.style.left = newBoxLeft + "px"
        }

此時(shí)效果圖如下:
如何用原生javascript實(shí)現(xiàn)輪播圖

3.2 實(shí)現(xiàn)自動(dòng)輪播功能

在定時(shí)器中每1500毫秒調(diào)用一次goNext方法,實(shí)現(xiàn)自動(dòng)切換圖片

// 使用setInterval()定時(shí)器實(shí)現(xiàn)自動(dòng)切換功能
        var timer        function autoChange() {
            timer = setInterval(goNext, 1500)
        }
        autoChange()
3.3 實(shí)現(xiàn)鼠標(biāo)懸停在圖片上時(shí),停止自動(dòng)切換,停留在當(dāng)前圖片,移出時(shí)繼續(xù)自動(dòng)切換
 // 監(jiān)聽鼠標(biāo)移入事件和移出事件,實(shí)現(xiàn)鼠標(biāo)懸停在圖片上時(shí),停止自動(dòng)切換,停留在當(dāng)前圖片,
 // 鼠標(biāo)移出時(shí)繼續(xù)自動(dòng)切換
        container.addEventListener('mouseenter', function() {
            clearInterval(timer)
        })
        container.addEventListener('mouseleave', autoChange)

此處補(bǔ)充一個(gè)小插曲

一開始我監(jiān)聽的是mouseout事件,但是在測試時(shí)發(fā)現(xiàn)鼠標(biāo)移出container盒子時(shí)會(huì)多次觸發(fā)mouseout事件,導(dǎo)致多次調(diào)用autoChange函數(shù),開啟了多個(gè)定時(shí)器,出現(xiàn)圖片切換混亂的情況,查了一下mouseout事件和mouseleave事件的區(qū)別:

  • mouseover和mouseout在父元素和其子元素都可以觸發(fā),當(dāng)鼠標(biāo)穿過一個(gè)元素時(shí),觸發(fā)次數(shù)得依子元素?cái)?shù)量而言。

  • mouseenter和mouseleave只在父元素觸發(fā),當(dāng)鼠標(biāo)穿過一個(gè)元素時(shí),只會(huì)觸發(fā)一次。

  • mouseover和mouseout比mouseenter和mouseleave先觸發(fā)

簡單來說就是

  • mouseout在所選區(qū)域內(nèi),從父元素到子元素也算移出觸發(fā)。

  • mouseleave,在所選區(qū)域,不管有沒有子元素,移出才會(huì)觸發(fā)。

3.4實(shí)現(xiàn)底部小圓圈跟隨圖片同步切換

實(shí)現(xiàn)原理:可以根據(jù)imgBox的left值,推算出第幾個(gè)小圓圈被選中,絕對(duì)值就是小圓圈的索引值,放張圖幫助理解(字有點(diǎn)丑,請忽略,嘻嘻。。)
如何用原生javascript實(shí)現(xiàn)輪播圖
在goLast()函數(shù)和goNext()函數(shù)中就可以計(jì)算/計(jì)算出被選中小圓圈的索引

 var index = 0 // 定義index變量,表示第幾個(gè)小圓圈被選中
 
 function goLast() {
            let newBoxLeft            if (imgBox.style.left === '0px') {
                newBoxLeft = -2000
            } else {
                // imgBox.style.left是一個(gè)字符串,所以要轉(zhuǎn)化為數(shù)字才能進(jìn)行計(jì)算,而設(shè)定left時(shí)就要加上px成為一個(gè)字符串
                newBoxLeft = parseInt(imgBox.style.left) + 500;
            }
            imgBox.style.left = newBoxLeft + "px"
            index = Math.abs(newBoxLeft / 500)  //計(jì)算出被選中小圓圈的索引
        }

 function goNext() {
            let newBoxLeft            if (imgBox.style.left === '-2000px') {
                newBoxLeft = 0
            } else {
                newBoxLeft = parseInt(imgBox.style.left) - 500;
            }
            imgBox.style.left = newBoxLeft + "px"
            index = Math.abs(newBoxLeft / 500)  ///計(jì)算出被選中小圓圈的索引
        }

完成3.2、3.3和3.4之后的效果圖如下:
如何用原生javascript實(shí)現(xiàn)輪播圖

3.5實(shí)現(xiàn)點(diǎn)擊底部某個(gè)小圓圈時(shí)切換成對(duì)應(yīng)的圖片
// 實(shí)現(xiàn)點(diǎn)擊底部某個(gè)小圓圈時(shí)切換成對(duì)應(yīng)的圖片
        (function clickCircle() {
            let circleArr = document.getElementsByTagName('li')
            for (let j = 0; j < circleArr.length; j++) {
                circleArr[j].addEventListener('click', () => {
                    index = j                    selectCircle()
                    imgBox.style.left = -(index * 500) + "px"
                })
            }
        })() //函數(shù)自調(diào)用寫法,格式:(函數(shù))()

效果圖如下:
如何用原生javascript實(shí)現(xiàn)輪播圖
到此為止,輪播圖的功能都實(shí)現(xiàn)了,但是作為一個(gè)強(qiáng)迫癥,發(fā)現(xiàn)自動(dòng)切換的時(shí)候,顯示左右箭頭并不好看,所以再做一點(diǎn)小小的調(diào)整。

3.6補(bǔ)充實(shí)現(xiàn)鼠標(biāo)懸停在圖片上時(shí),顯示左右箭頭,移出時(shí)隱藏左右箭頭
//給左右箭頭默認(rèn)隱藏<a href="javascript:;" class="leftArrow" style="display: none;">
    <img src="./images/leftArrow.png" alt="左箭頭"></a><a href="javascript:;" class="rightArrow" style="display: none;">
    <img src="./images/rightArrow.png" alt="右箭頭"></a>

在監(jiān)聽鼠標(biāo)事件中,改為以下代碼

// 監(jiān)聽鼠標(biāo)移入事件和移出事件,實(shí)現(xiàn)鼠標(biāo)懸停在圖片上時(shí),停止自動(dòng)切換,停留在當(dāng)前圖片,鼠標(biāo)移出時(shí)繼續(xù)自動(dòng)切換
        container.addEventListener('mouseenter', function() {
            clearInterval(timer)
            leftArrow.style.display = "inline"
            rightArrow.style.display = "inline"
        })
        container.addEventListener('mouseleave', function() {
            autoChange()
            leftArrow.style.display = "none"
            rightArrow.style.display = "none"
        })

效果圖:
如何用原生javascript實(shí)現(xiàn)輪播圖
到這就結(jié)束了。

下面是完整代碼。

<!DOCTYPE html><html lang="en"><head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>原生js實(shí)現(xiàn)輪播圖——小肉包</title>
    <style>
        /* 內(nèi)聯(lián)樣式表 */
        
        * {
            margin: 0;
            padding: 0;
        }
        
        li {
            list-style: none;
        }
        /* 外層容器樣式 */
        
        .container {
            height: 330px;
            width: 500px;
            margin: 100px auto;
            position: relative;
            overflow: hidden;
        }
        /* 左右箭頭樣式 */
        
        .container .leftArrow,
        .container .rightArrow {
            position: absolute;
            top: 50%;
            transform: translate(0, -50%);
            z-index: 1;
            width: 32px;
            height: 32px;
        }
        
        .container .leftArrow {
            left: 5px;
        }
        
        .container .rightArrow {
            right: 5px;
        }
        /* 圖片盒子樣式 */
        
        .imgBox {
            position: absolute;
            /* transition: all 0.5s; */
            height: 333px;
            width: 3500px;
        }
        
        .imgBox img {
            height: 330px;
            width: 500px;
            float: left;
        }
        /* 底部小圓圈樣式 */
        
        .circleFather {
            position: absolute;
            bottom: 10px;
            left: 50%;
            transform: translate(-50%, 0);
        }
        
        .circleFather li {
            float: left;
            height: 10px;
            width: 10px;
            margin: 0 5px;
            border: 2px solid #e7641c;
            border-radius: 50%;
        }
        
        .select {
            background-color: #e7641c;
        }
    </style></head><body>
    <!-- 結(jié)構(gòu)部分 -->
    <!-- 結(jié)構(gòu)說明:外層一個(gè)container盒子,用于放圖片盒子(imgBox)、左箭頭、右箭頭、底部小圓圈, 
        圖片盒子中放的是輪播的圖片 -->
    <p class="container">
        <!-- 注意:此處強(qiáng)調(diào)一下,圖片盒子imgBox的left屬性必須寫成行內(nèi)樣式,否則js中拿不到left的值 -->
        <p class="imgBox" style="left: 0px;">
            <!-- <img src="./images/lunbo5.jpg" alt="輪播圖5"> -->
            <img src="./images/lunbo1.jpg" alt="輪播圖1">
            <img src="./images/lunbo2.jpg" alt="輪播圖2">
            <img src="./images/lunbo3.jpg" alt="輪播圖3">
            <img src="./images/lunbo4.jpg" alt="輪播圖4">
            <img src="./images/lunbo5.jpg" alt="輪播圖5">
            <!-- <img src="./images/lunbo1.jpg" alt="輪播圖1"> -->
        </p>

        <a href="javascript:;" class="leftArrow" style="display: none;">
            <img src="./images/leftArrow.png" alt="左箭頭">
        </a>
        <a href="javascript:;" class="rightArrow" style="display: none;">
            <img src="./images/rightArrow.png" alt="右箭頭">
        </a>

        <ul class="circleFather">
            <li class="select"></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </p>



    <!-- JavaScript部分 -->
    <script type="text/javascript">
        var container = document.querySelector('.container') //獲取外層容器盒子
        var imgBox = document.querySelector('.imgBox') //獲取圖片盒子
        var leftArrow = document.querySelector('.leftArrow') //獲取左箭頭
        var rightArrow = document.querySelector('.rightArrow') //獲取右箭頭
        var index = 0 // 定義index變量,表示第幾個(gè)小圓圈被選中


        //給左箭頭綁定點(diǎn)擊事件
        leftArrow.onclick = function() {
            goLast()
        }

        //右箭頭點(diǎn)擊事件
        rightArrow.onclick = function() {
            goNext()
        }

        // 顯示上一張圖片
        // 1.點(diǎn)一次左箭頭,就讓left值-500,點(diǎn)一次右箭頭,就讓left值+500
        // 2.但是有兩種特殊情況,(1)當(dāng)前展示圖片1時(shí),點(diǎn)擊左箭頭則需展示圖片5,(2)當(dāng)前展示圖片5時(shí),點(diǎn)擊右箭頭則需展示圖片1
        function goLast() {
            let newBoxLeft            if (imgBox.style.left === '0px') {
                newBoxLeft = -2000
            } else {
                // imgBox.style.left是一個(gè)字符串,所以要轉(zhuǎn)化為數(shù)字才能進(jìn)行計(jì)算,而設(shè)定left時(shí)就要加上px成為一個(gè)字符串
                newBoxLeft = parseInt(imgBox.style.left) + 500;
            }
            imgBox.style.left = newBoxLeft + "px"
            index = Math.abs(newBoxLeft / 500) //計(jì)算第幾個(gè)小圓圈被選中
            selectCircle()
        }

        // 顯示下一張圖片
        function goNext() {
            let newBoxLeft            if (imgBox.style.left === '-2000px') {
                newBoxLeft = 0
            } else {
                newBoxLeft = parseInt(imgBox.style.left) - 500;
            }
            imgBox.style.left = newBoxLeft + "px"
            index = Math.abs(newBoxLeft / 500)
            selectCircle()
        }

        // 使用setInterval()定時(shí)器實(shí)現(xiàn)自動(dòng)切換功能
        function autoChange() {
            timer = setInterval(goNext, 1500)
        }
        autoChange()

        // 監(jiān)聽鼠標(biāo)移入事件和移出事件,實(shí)現(xiàn)鼠標(biāo)懸停在圖片上時(shí),停止自動(dòng)切換,停留在當(dāng)前圖片,鼠標(biāo)移出時(shí)繼續(xù)自動(dòng)切換
        container.addEventListener('mouseenter', function() {
            clearInterval(timer)
            leftArrow.style.display = "inline"
            rightArrow.style.display = "inline"
        })
        container.addEventListener('mouseleave', function() {
            autoChange()
            leftArrow.style.display = "none"
            rightArrow.style.display = "none"
        })


        //實(shí)現(xiàn)底部小圓圈跟隨圖片同步切換
        function selectCircle() {
            //獲取所有的小圓圈偽數(shù)組
            let circleArr = document.getElementsByTagName('li')
            for (let i = 0; i < circleArr.length; i++) {
                circleArr[i].className = ""
            }
            circleArr[index].className = 'select'
        }



        // 實(shí)現(xiàn)點(diǎn)擊底部某個(gè)小圓圈時(shí)切換成對(duì)應(yīng)的圖片
        (function clickCircle() {
            let circleArr = document.getElementsByTagName('li')
            for (let j = 0; j < circleArr.length; j++) {
                circleArr[j].addEventListener('click', () => {
                    index = j                    selectCircle()
                    imgBox.style.left = -(index * 500) + "px"
                })
            }
        })() //函數(shù)自調(diào)用寫法,格式:(函數(shù))()
    </script></body></html>

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何用原生javascript實(shí)現(xiàn)輪播圖”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

分享標(biāo)題:如何用原生javascript實(shí)現(xiàn)輪播圖
網(wǎng)頁URL:http://aaarwkj.com/article2/jejcic.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、品牌網(wǎng)站設(shè)計(jì)、App開發(fā)網(wǎng)站改版、關(guān)鍵詞優(yōu)化自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站建設(shè)
欧美成人午夜精品一区二区| 日韩欧美亚洲另类激情一区| 区一区二区三视频日韩| 免费在线观看福利av| 91香蕉国产在线观看| 成人午夜黄色福利视频| 国产饥渴熟女在线三区| 中午字幕久久亚洲精品| 最新日本免费久久精品| 久久精品亚洲欧美激情| 欧美日韩欧美日韩一区二区| 午夜视频在线观看麻豆| 亚洲av网站一区二区三区| 中文字幕一区二区不卡顿| 国产婷婷色三区一区二区| 久久精品熟女亚洲av色| 欧美日韩亚洲中文国产| 国产日韩综合精品一区| 亚洲第一精品国产日韩| 国产成人久久久精品一区| 日韩av中文一区二区| 蜜桃精品国产一区二区三区| 免费黄片视频大全在线播放| 国产超大超粗超爽视频| 亚洲精品天堂av免费看| 亚洲欧美中文日韩二区一区| 国产青草视频免观看视频| 亚洲国产欧美日韩在线| 成人大片在线免费观看视频| 日本一区二区三区免费精品| 萌白的所有视频在线观看| 亚洲欧美日韩国产精品专区| 国产欧美成人综合色就色| 五月婷婷丁香在线观看| 欧美a级黄片免费在线观看| 国产综合亚洲欧美日韩在线| 久久国产亚洲欧美日韩精品| 日韩成人在线视频中文字幕| 精品少妇人妻久久av免费| 97资源在线公开视频| 日本乱码中文字幕在线观看|