靈活使用數(shù)組制作圖片切換js實(shí)現(xiàn)
js活用數(shù)組制作圖片切換效果,供大家參考,具體內(nèi)容如下
數(shù)組元素位置變換:
將內(nèi)容分割為數(shù)組,將第一個(gè)加到最后,刪掉第一個(gè)
<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]);//將第一個(gè)加到最后,刪掉第一個(gè) arr.shift(); oDiv.innerHTML=arr; } } </script>
模擬圖片切換效果:
window.onload=function(){ var aDiv=document.getElementsByTagName('div'); var aInput=document.getElementsByTagName('input'); var arr=[];//創(chuàng)建空數(shù)組用于存放屬性 for(var i=0;i<aDiv.length;i++){ console.dir(getStyle(aDiv[i],'left'));//獲取到純凈的最終樣式 //將屬性作為 符合數(shù)組 加入arr中,可用于多屬性 arr.push([getStyle(aDiv[i],'left'),getStyle(aDiv[i],'top')]); } // console.dir(arr); aInput[0].onclick=function(){//將第一個(gè)加到最后,刪掉第一個(gè) arr.push(arr[0]); arr.shift(); for(var i=0;i<aDiv.length;i++){//操作完數(shù)組后重新賦值 aDiv[i].style.left=arr[i][0]; aDiv[i].style.top=arr[i][1]; } }; aInput[1].onclick=function(){//將最后一個(gè)加到最前,刪最后 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]; } } }
簡陋效果圖:
實(shí)例版:
思路:
若有五張圖片:圖1~5的left值分別為:20px、60px、100px、240px、380px;
點(diǎn)擊左切換按鈕后,對應(yīng)的圖1~5left值變?yōu)椋?0px、100px、240px、380px、20px;
--------------------------------------------------------------------------------
相當(dāng)于這組數(shù)組第一個(gè)元素移到最后:20px、60px、100px、240px、380px、20px;
然后再把第一個(gè)元素刪除得:60px、100px、240px、380px、20px;
以此類推:
實(shí)例布局:
<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>
實(shí)例樣式:
#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){//得到是帶單位的數(shù)值 if(obj.currentStyle){ return obj.currentStyle[attr]; }else{ return getComputedStyle(obj,false)[attr]; } } }
效果圖:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
20行JS代碼實(shí)現(xiàn)網(wǎng)頁刮刮樂效果
下面小編就為大家?guī)硪黄?0行JS代碼實(shí)現(xiàn)網(wǎng)頁刮刮樂效果。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06vue2.0實(shí)戰(zhàn)之基礎(chǔ)入門(1)
這篇文章主要為大家詳細(xì)介紹了vue2.0實(shí)戰(zhàn)第一篇基礎(chǔ)入門的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03js實(shí)現(xiàn)數(shù)組冒泡排序、快速排序原理
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)數(shù)組冒泡排序、快速排序的原理,感興趣的小伙伴們可以參考一下2016-03-03如何在JavaScript中創(chuàng)建具有多個(gè)空格的字符串?
這篇文章主要介紹了如何在JavaScript中創(chuàng)建具有多個(gè)空格的字符串?,需要的朋友可以參考下2020-02-02JavaScript 模塊的循環(huán)加載實(shí)現(xiàn)方法
本文介紹JavaScript語言如何處理"循環(huán)加載"。目前,最常見的兩種模塊格式CommonJS和ES6,處理方法是不一樣的,返回的結(jié)果也不一樣2015-12-12JavaScript實(shí)現(xiàn)的select點(diǎn)菜功能示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)的select點(diǎn)菜功能,涉及javascript動(dòng)態(tài)操作頁面元素及元素遍歷相關(guān)技巧,需要的朋友可以參考下2017-01-01