js活用配列作成画像切り替え

19975 ワード

配列要素の位置変換:
コンテンツを配列に分割し、最初のものを最後に追加し、最初のものを削除します.
<div id="box">1,2,3,4</div>
<input type="button" value='  ' id='input'>
<script> window.onload=function(){ var oDiv=document.getElementById('box'); var oInput=document.getElementById('input'); oInput.onclick=function(){ var arr=oDiv.innerHTML.split(','); // console.log(arr); arr.push(arr[0]);//        ,      arr.shift(); oDiv.innerHTML=arr; } } </script>
アナログ画像の切り替え効果:
window.onload=function(){
    var aDiv=document.getElementsByTagName('div');
    var aInput=document.getElementsByTagName('input');
    var arr=[];//           

    for(var i=0;i<aDiv.length;i++){
        console.dir(getStyle(aDiv[i],'left'));//          
        //             arr ,      
                 arr.push([getStyle(aDiv[i],'left'),getStyle(aDiv[i],'top')]);
    }
    // console.dir(arr);

    aInput[0].onclick=function(){//        ,     
        arr.push(arr[0]);
        arr.shift();
        for(var i=0;i<aDiv.length;i++){//          
            aDiv[i].style.left=arr[i][0];
            aDiv[i].style.top=arr[i][1];
        }
    };
    aInput[1].onclick=function(){//         ,   
        arr.unshift(arr[arr.length-1]);
        arr.pop();
        for(var i=0;i<aDiv.length;i++){
            aDiv[i].style.left=arr[i][0];
            aDiv[i].style.top=arr[i][1];
        }
    };
    function getStyle(obj,attr){//      
        if(obj.currentStyle){
            return obj.currentStyle[attr];
        }else{
            return getComputedStyle(obj,false)[attr];
        }
    }
}
単純効果図:
インスタンス:
考え方:5枚の画像があれば、図1~5のleft値はそれぞれ20 px、60 px、100 px、240 px、380 pxである.左切り替えボタンをクリックすると、対応する図1〜5 leftの値が60 px、100 px、240 px、380 px、20 pxになります.
この配列の最初の要素に相当して、最後に移動します.20 px、60 px、100 px、240 px、380 px、20 px.その後、最初の要素を60 px、100 px、240 px、380 px、20 pxに削除します.これをもって類推する:
インスタンスレイアウト:
<div id="box">
    <ul>
        <li class='pos_0'><img src="images/1.png" width='300'></li>
        <li class='pos_1'><img src="images/1.jpg" width='400'></li>
        <li class='pos_2'><img src="images/2.jpg" width='500'></li>
        <li class='pos_3'><img src="images/3.jpg" width='400'></li>
        <li class='pos_4'><img src="images/1.jpg" width='300'></li>
    </ul>
    <span class='dir dirl'></span>
    <span class='dir dirr'></span>
</div>
インスタンススタイル:
#box{width:700px;height:300px;position:relative;margin:20px auto;text-align: center;}
#box ul{list-style: none;}
#box ul li{position:absolute;}
#box ul li.pos_0{top:50px;left:20px;z-index:1;opacity:0.5;}
#box ul li.pos_1{top:20px;left:60px;z-index:2;opacity:0.8;}
#box ul li.pos_2{top:0px;left:100px;z-index:3;opacity:1;}
#box ul li.pos_3{top:20px;left:240px;z-index:2;opacity:0.8;}
#box ul li.pos_4{top:50px;left:380px;z-index:1;opacity:0.5;}
.dir{display: inline-block;width:45px;height:100px;background:url('images/button.png') no-repeat; position:absolute;top:60px;z-index:4;}
.dirl{background-position: 0px 0;left:40px;}
.dirr{background-position: -55px 0;right:40px;}
JSコード:
window.onload=function(){
    var oPre=document.getElementsByClassName('dir')[0];
    var oNext=document.getElementsByClassName('dir')[1];
    var aLi=document.getElementsByTagName('li');
    var arr=[];
    for(var i=0;i<aLi.length;i++){
        var oImg=aLi[i].getElementsByTagName('img')[0];
        // console.log(getStyle(aLi[i],'left'));
        // console.log(parseInt(getStyle(aLi[i],'opacity')*100));
        // console.log(getStyle(aLi[i],'z-index'));
        // console.log(oImg.width);
        arr.push([
            parseInt(getStyle(aLi[i],'top')),
            parseInt(getStyle(aLi[i],'opacity')*100),
            parseInt(getStyle(aLi[i],'z-index')),
            oImg.width
            ]);
        // console.log(arr[i][2]);
    }
    // console.dir(arr);
    oPre.onclick=function(){// 
        arr.push(arr[0]);
        arr.shift();
        for(var i=0;i<aLi.length;i++){

            var oImg=aLi[i].getElementsByTagName('img')[0];
            //console.log(arr[i][2]);
            startMove(aLi[i],{
                left:arr[i][0],
                top:arr[i][1],
                opacity:arr[i][2],
            });
            aLi[i].style.zIndex=arr[i][3];
            startMove(oImg,{width:arr[i][4]});
        }
    };
    oNext.onclick=function(){// 
        arr.unshift(arr[arr.length-1]);
        arr.pop();
        for(var i=0;i<aLi.length;i++){

            var oImg=aLi[i].getElementsByTagName('img')[0];

            startMove(aLi[i],{
                left:arr[i][0],
                top:arr[i][1],
                opacity:arr[i][2],
            });

            aLi[i].style.zIndex=arr[i][3];
            startMove(oImg,{width:arr[i][4]});
        }
    };
    function getStyle(obj,attr){//         
        if(obj.currentStyle){
            return obj.currentStyle[attr];
        }else{
            return getComputedStyle(obj,false)[attr];
        }
    }
}
効果図: