92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线

原生代碼之實現輪播圖(左右翻頁,定時翻頁,指定翻頁)

2020-3-15    前端達人

首先在寫代碼之前我們需要理清如何穿插圖片呢?



可以讓所有圖片都float:left,用一個大盒子裝進所有圖片,在用一個小盒子顯示圖片,溢出圖片就hidden,之后以每張圖片的寬度來scrollLeft.

可以給每張圖片一個name/id,用循環遍歷所有圖片

可以用float:left,但是除了我要顯示的圖片外,其他圖片都hidden,之后每當我需要某張圖片時,我就把它制定到某位置



在這里,我將用第二種方法,因為它很直觀明了,我要哪張圖片我就調哪張圖片。

HTML部分:在div里面我裝了一張圖片,name:0, 這是為了在剛打開的時候,我們的頁面是有東西的而不是一片空白。其他部分都好理解,不理解的可在下方評論。

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title>輪播圖</title>
        <link rel="stylesheet" href="輪播圖.css" />
        <script src="輪播圖.js">
        </script>
    </head>

    <body>
        <header>
            <div id="oImg">
                <!-- 輪流播放圖片 -->
                <img id="insert" src="img/輪1.jpg" name="0"/>
            </div>
            <!-- 左右切換圖片 -->
            <p id="left" οnclick="goBack()"></p>
            <p id="right" οnclick="goForward()"></p>

            <ul id="nav">
                <!-- 指定某張圖片 -->
                <li id="1" οnclick="move(this)">1</li>
                <li id="2" οnclick="move(this)">2</li>
                <li id="3" οnclick="move(this)">3</li>
                <li id="4" οnclick="move(this)">4</li>
                <li id="5" οnclick="move(this)">5</li>
            </ul>
        </header>

    </body>

</html>

CSS:
* {
    margin: 0 auto;
    padding: 0 auto;
}

header {
    width: 100%;
    height: 680px;
    position: relative;

}

img {
    width: 100%;
    height: 680px; 
}   

#nav { 
    position: absolute;
    bottom: 5px;
    left: 30%;
}

#nav li {
    width: 30px;
    height: 30px;
    line-height: 30px;
    text-align: center;
    background: #ccc;
    font-size: 24px;
    border-radius: 9px;
    color: darkslategrey;
    font-family: 'Times New Roman', Times, serif;
    margin: 0 25px;
    float: left;
    cursor: pointer;
    list-style: none;
}

#nav li:hover {
    background: peru;
}

#left {
    width: 25px;
    height: 24px;
    left: 0;
    top: 50%;
    cursor: pointer;
    position: absolute;
    background: url(img/fx1.png);
}

#right {
    width: 25px;
    height: 24px;
    right: 0;
    top: 50%;
    cursor: pointer;
    position: absolute;
    background: url(img/fx2.png);
}
之后我們來看重中之重JS部分
JavaScript:
// 五張圖片的url
var oImg1 = "img/輪1.jpg";
var oImg2 = "img/輪2.jpg";
var oImg3 = "img/輪3.jpg";
var oImg4 = "img/輪4.jpg";
var oImg5 = "img/輪5.jpg";
// 把5張圖片存入一個數組
var arr = [oImg1, oImg2, oImg3, oImg4, oImg5];

window.onload = function() {
    //剛加載時第一張圖片1號背景顏色
    document.getElementById("1").style.background = "peru";  
    run()

}

//輪播
function run() { 
    timer = setInterval(function() {
        //隨機點數字時能接著變化 
        var pic = document.getElementById("insert").name;
        var shade = document.getElementById("insert");  

        //如果為最后一張圖片則重新循環
        if (pic == 4) {
            pic = -1;
        }

        //點一個數字該數字背景顏色變化其余的不變
        var aLi = document.getElementsByTagName("li");
        for (var j = 0; j < aLi.length; j++) {
            aLi[j].style.backgroundColor = "#CCCCCC";
        } 

        var i = parseInt(pic);   

        document.getElementById("insert").src = arr[i + 1]; 

        document.getElementById("insert").name = i + 1; 

        //數字隨圖片變化
        switch (i) {
            case 0:
                var temp = '2';
                break;
            case 1:
                var temp = '3';
                break;
            case 2:
                var temp = '4';
                break;
            case 3:
                var temp = '5';
                break;
            case -1:
                var temp = '1';
                break;
        }
        document.getElementById(temp).style.background = "peru"   

    }, 5000)
}

//右箭頭 
function goForward() {
    var temp = document.getElementById("insert").name;
    var oBox = document.getElementById("insert"); 
    var aLi = document.getElementsByTagName("li");
    // 數字跟著圖片一起變
    for (var i = 0; i < aLi.length; i++) {
        aLi[i].style.backgroundColor = "#CCCCCC";
    }

    switch (temp) {
        case "0":
            var n = '2';
            break;
        case "1":
            var n = '3';
            break;
        case "2":
            var n = '4';
            break;
        case "3":
            var n = '5';
            break;
        case "4":
            var n = '1';
            break;
    }

    document.getElementById(n).style.background = "peru"
    // 向右移動圖片
    for (var j = 0; j < arr.length; j++) {
        if (j < 4) {
            if (temp == j) {
                oBox.src = arr[j + 1]; 
            }
        } else {
            if (temp == 4) {
                oBox.src = arr[0]; 
            }
        }
    } 
    // 輪到最后一張圖片時返回第一張
    if (temp < 4) {
        oBox.name = parseInt(temp) + 1;
    } else {
        oBox.name = 0;
    }
}

//左箭頭
function goBack() {
    var temp = document.getElementById("insert").name;
    var oBox = document.getElementById("insert")
    var aLi = document.getElementsByTagName("li");
    // 圖片移動時數字也跟著變
    for (var i = 0; i < aLi.length; i++) {
        aLi[i].style.backgroundColor = "#CCCCCC";
    }

    switch (temp) {
        case "0":
            var n = '5';
            break;
        case "1":
            var n = '1';
            break;
        case "2":
            var n = '2';
            break;
        case "3":
            var n = '3';
            break;
        case "4":
            var n = '4';
            break;
    }

    document.getElementById(n).style.background = "peru"
    // 向左移動圖片 

    for (var j = 0; j < arr.length; j++) {
        if (j > 0) {
            if (temp == j) {
                oBox.src = arr[j - 1];
            }
        } else {
            if (temp == 0) {
                oBox.src = arr[4];
            }
        }
    }
    // 輪到第一張圖片時返回最后一張
    if (temp > 0) {
        oBox.name = parseInt(temp) - 1;
    } else {
        oBox.name = 4;
    }
}

//指定圖片
function move(num) { 
    var oBox = document.getElementById("insert");
    var temp = document.getElementById("insert").name;
    var aLi = document.getElementsByTagName("li");
    for (var i = 0; i < aLi.length; i++) {
        aLi[i].style.backgroundColor = "#CCCCCC";
    }

    document.getElementById(num.innerHTML).style.background = "peru"

    switch (num.innerHTML) {
        case "1":
            oBox.src = arr[0];
            oBox.name = 0;
            break;
        case "2":
            oBox.src = arr[1];
            oBox.name = 1;
            break;
        case "3":
            oBox.src = arr[2];
            oBox.name = 2;
            break;
        case "4":
            oBox.src = arr[3];
            oBox.name = 3;
            break;
        case "5":
            oBox.src = arr[4];
            oBox.name = 4;
            break;
    }
}
JavaScript部分我寫的很詳細,仔細看的話是可以看懂的,主要分3個重要部分:

用src來調用每張圖片并給每張圖片一個name,這樣方便后面的重復使用
為下方的數字按鈕匹配圖片,點擊1跳到第1張圖片,點擊2跳到第2張圖片…因為我把所有的圖片都存在了一個數組里,所以在匹配的時候要注意數組0位置才是數字1指定的圖片
可以來回翻頁,當到達最后一張圖片時,我再點擊下一張圖片又能返回到第一張圖片了,亦或者當我點擊到第一張圖片時,再上一張圖片又回到第五張圖片了
效果如下:

點擊查看原圖

點擊查看原圖

大家有問題可以在下方評論哦,看到了會及時回復噠!


————————————————
版權聲明:本文為CSDN博主「weixin_43964414」的原創文章,遵循 CC 4.0 BY-SA 版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/weixin_43964414/article/details/104844041

日歷

鏈接

個人資料

藍藍設計的小編 http://www.skdbbs.com

存檔

92国产精品视频_亚洲a级在线观看_国产精品电影观看_国产精品免费观看在线_精品伊人久久97_亚洲人成在线观_尤物九九久久国产精品的特点_成人激情在线播放_成人黄色大片在线免费观看_亚洲成人精品久久久_久久免费视频在线观看_久久精品国产一区_国产一区二区三区18_亚洲欧美中文字幕在线一区_日韩美女中文字幕_日韩视频免费在线
国产成人中文字幕| 精品久久久久国产| 91精品久久久久久久久中文字幕| 一区二区三区四区在线观看视频| 欧美第一淫aaasss性| 26uuu另类亚洲欧美日本一| 最近2019中文字幕mv免费看| 欧美在线性视频| 高潮白浆女日韩av免费看| 欧美老肥婆性猛交视频| 国产成+人+综合+亚洲欧洲| 成人www视频在线观看| 欧美激情综合色综合啪啪五月| 色综合亚洲精品激情狠狠| 色老头一区二区三区| 久久久久北条麻妃免费看| 国产欧美日韩精品丝袜高跟鞋| 中文字幕不卡在线视频极品| 成人黄色短视频在线观看| 日本精品性网站在线观看| 97热精品视频官网| 国产成人一区二区| 日韩在线免费高清视频| 欧美综合在线第二页| 亚洲成人久久久| 欧美日韩美女在线观看| 国产成人拍精品视频午夜网站| 欧美成人在线免费视频| 欧美黄色性视频| 色99之美女主播在线视频| 欧美精品制服第一页| 久久精品成人动漫| 欧日韩在线观看| 亚洲欧美综合v| 日韩美女写真福利在线观看| 国产一区欧美二区三区| 国产精品视频中文字幕91| 日韩不卡中文字幕| 亚洲精品日韩激情在线电影| 亚洲成在人线av| 91精品久久久久久久久中文字幕| 国产欧美一区二区三区四区| 色婷婷久久av| 91在线观看欧美日韩| 韩国19禁主播vip福利视频| 欧美亚洲视频在线看网址| 欧美大片网站在线观看| 亚洲娇小xxxx欧美娇小| 精品美女国产在线| 7777精品视频| 91精品美女在线| 亚洲一区二区三区四区视频| 国产999精品久久久| 国产精品一区二区三区久久| 国产不卡av在线| 国外色69视频在线观看| 在线视频欧美日韩| 久久综合久久88| 成人亚洲欧美一区二区三区| 成人网欧美在线视频| 日本精品久久久久久久| 欧美大尺度激情区在线播放| www.久久色.com| 欧美日韩精品国产| 大伊人狠狠躁夜夜躁av一区| 日本精品久久中文字幕佐佐木| 国自在线精品视频| 国产精品影片在线观看| 欧美日韩中文在线| 成人激情在线播放| 国产玖玖精品视频| 国产精品羞羞答答| 国产精品亚洲自拍| 欧美中在线观看| 日韩精品极品在线观看播放免费视频| 91精品国产91久久久久久吃药| 色99之美女主播在线视频| 欧美性高潮在线| 中文字幕少妇一区二区三区| 成人有码视频在线播放| 欧美日韩国产综合视频在线观看中文| 国产精品福利在线观看网址| 欧美日韩国产中文精品字幕自在自线| 日韩欧美在线视频日韩欧美在线视频| 亚洲在线免费看| 日本高清不卡在线| 成人写真福利网| 欧美老女人bb| 国产精品电影网站| 亚洲天堂第一页| 91福利视频网| 国产精品高潮呻吟久久av无限| 97在线观看免费| 亚洲黄色有码视频| 国产精品福利小视频| 欧美丰满少妇xxxx| 原创国产精品91| 国产精品偷伦视频免费观看国产| 亚洲xxxx18| 亚洲欧洲一区二区三区久久| 成人黄色片在线| 国产成人精品亚洲精品| 国产精品视频26uuu| 欧美视频在线观看 亚洲欧| 国产精品视频yy9099| 亚洲欧美国内爽妇网| 亚洲第一区中文99精品| 日韩欧美精品在线观看| 日韩精品极品在线观看播放免费视频| 琪琪亚洲精品午夜在线| 久久精视频免费在线久久完整在线看| 九九九久久国产免费| 国产91对白在线播放| 91精品视频在线免费观看| 亚洲片在线资源| 2020国产精品视频| 97精品欧美一区二区三区| 91高清视频免费| 国产一区av在线| 亚洲激情电影中文字幕| 精品国产一区久久久| 久久69精品久久久久久久电影好| 亚洲视屏在线播放| 亚洲成人av在线| 亚洲激情免费观看| 亚洲国产中文字幕久久网| 岛国av在线不卡| 一本一道久久a久久精品逆3p| 久久久久久成人精品| 一区二区欧美在线| 精品一区二区三区四区在线| 久久久久国产精品免费网站| 国产一区二区三区在线看| 欧美视频专区一二在线观看| 国产丝袜一区二区三区免费视频| 91精品在线国产| 日韩中文字幕国产精品| 一区二区在线免费视频| 国产区精品在线观看| 欧美日韩中文在线观看| 亚洲综合日韩在线| 亚洲色图偷窥自拍| 日本一区二区三区在线播放| 亚洲精品欧美一区二区三区| 欧亚精品在线观看| 国产精品一香蕉国产线看观看| 91久久久久久久久久久久久| 91亚洲国产成人精品性色| 色妞色视频一区二区三区四区| 欧美激情视频在线| 欧美日韩福利电影| 欧美孕妇性xx| 久久精品亚洲国产| 亚洲欧美成人精品| 黑人巨大精品欧美一区二区三区| 欧亚精品中文字幕| 狠狠色狠狠色综合日日小说| 最新91在线视频| 亚洲欧美中文日韩在线| 狠狠躁天天躁日日躁欧美| 欧美一区二区三区四区在线| 91高潮精品免费porn| 亚州成人av在线| 欧美成人h版在线观看|