1. 程式人生 > >JS——初級輪播圖的實現(橫向)

JS——初級輪播圖的實現(橫向)

描述:

輪播圖,初級,橫向buton或者底部數字控制輪播,可以實現自動輪播(註釋了,使用的話將其註釋消掉),核心知識是資料驅動影象的位移達到效果。

效果:

程式碼:

js檔案:

/*
* 工廠模式
* */

var Method=(function () {
    return {
        loadImage:function (arr,callback) {
            var img=new Image();
            img.arr=arr;
            img.list=[];
            img.num=0;
            img.callback=callback;
//            如果DOM物件下的事件偵聽沒有被刪除掉,將會常駐堆中
//            一旦觸發了這個事件需要的條件,就會繼續執行事件函式
            img.addEventListener("load",this.loadHandler);
            img.self=this;
            img.src=arr[img.num];
        },

        loadHandler:function (e) {
            this.list.push(this.cloneNode(false));
            this.num++;
            if(this.num>this.arr.length-1){
                this.removeEventListener("load",this.self.loadHandler);
                this.callback(this.list);
                return;
            }
            this.src=this.arr[this.num];
        },

        $c:function (type,parent,style) {
            var elem=document.createElement(type);
            if(parent) parent.appendChild(elem);
            for(var key in style){
                elem.style[key]=style[key];
            }
            return elem;
        }
    }
})();

html檔案:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        #carousel,#imgCon img{
            width: 1200px;
            height: 400px;
        }
        #carousel
        {
            position: relative;
            margin: auto;
            overflow: hidden;
        }
        #imgCon{
            width: 6000px;
            height: 400px;
            position: absolute;
            left: 0;
            font-size: 0;
            transition: all 1s;
        }
        #leftBn,#rightBn
        {
            position: absolute;
            top:170px;
        }
        #leftBn{
            left: 20px;
        }
        #rightBn
        {
            right: 20px;
        }
        ul{
            position: absolute;
            bottom: 20px;
            list-style: none;
            margin: auto;
            left: 45%;
        }
        li
        {
            width: 20px;
            height: 20px;
            border: 1px solid red;
            border-radius: 10px;
            float: left;
            text-align: center;
            color: white;
            cursor: default;
            line-height:20px;
            font-size: 12px;
            margin-left: 8px;
        }
    </style>
</head>
<body>
    <div id="carousel">
        <div id="imgCon">
            <img src="img/a.jpeg">
            <img src="img/b.jpeg">
            <img src="img/c.jpeg">
            <img src="img/d.jpeg">
            <img src="img/e.jpeg">
        </div>
        <ul>
            <li>1</li>
            <li>2</li>
            <li>3</li>
            <li>4</li>
            <li>5</li>
        </ul>
        <img src="img/left.png" id="leftBn">
        <img src="img/right.png" id="rightBn">
    </div>
<script>
    /*
    *
    *  資料驅動顯示
    *
    * */
    var imgCon,leftBn,rightBn,lis,ul,prevLi;
    var position=0;//影象的標記 第一張0 第二張1...
    init();
    function init() {
        imgCon=document.getElementById("imgCon");//圖
        leftBn=document.getElementById("leftBn");//左按鈕
        rightBn=document.getElementById("rightBn");//右按鈕
        lis=document.getElementsByTagName("li");//下方數字右按鈕
        ul=document.getElementsByTagName("ul")[0];
        leftBn.addEventListener("click",clickHandler);
        rightBn.addEventListener("click",clickHandler);
        for(var i=0;i<lis.length;i++){//為每隔小Li 也就是底部數字賦值
            lis[i].num=i;
            lis[i].addEventListener("click",liClickHandler);
        }
        changeLi();
    }

//    setInterval(autoImg,3000);可以實現自動

    function autoImg() {//自動輪播
        position++;
        if(position>4) position=0;
        changeImg();
    }

    function clickHandler(e) {
        e= e || window.event;
        if(this===leftBn){
            position--;
            if(position<0) position=4;
        }else if(this===rightBn){
            position++;
            if(position>4) position=0;
        }
        changeImg();
    }

    function liClickHandler(e) {
        e= e || window.event;
        position=this.num;
        changeImg();
    }
    function changeImg() {//圖片的轉換效果 唯一
        imgCon.style.left=-position*1200+"px";//一次一張圖片的位移
        changeLi();
    }

    function changeLi() {//底部數字的轉換效果
        if(prevLi){
            prevLi.style.backgroundColor="rgba(255,0,0,0)";
        }
        prevLi=lis[position];
        prevLi.style.backgroundColor="rgba(255,0,0,0.5)";
    }
</script>
</body>
</html>