灵活使用数组制作图片切换js实现
2019-01-05
编程之家
https://www.jb51.cc
编程之家收集整理的这篇文章主要介绍了灵活使用数组制作图片切换js实现,编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
js活用数组制作图片切换效果,供大家参考,具体内容如下
数组元素位置变换:
将内容分割为数组,将第一个加到最后,删掉第一个
Box">1,2,3,4
模拟图片切换效果:
属性
for(var i=0;i
console.dir(getStyle(aDiv[i],'left'));//获取到纯净的最终样式
//将属性作为 符合数组 加入arr中,可用于多属性
arr.push([getStyle(aDiv[i],'left'),getStyle(aDiv[i],'top')]);
}
// console.dir(arr);
aInput[0].οnclick=function(){//将第一个加到最后,删掉第一个
arr.push(arr[0]);
arr.shift();
for(var i=0;i
aDiv[i].style.left=arr[i][0];
aDiv[i].style.top=arr[i][1];
}
};
aInput[1].οnclick=function(){//将最后一个加到最前,删最后
arr.unshift(arr[arr.length-1]);
arr.pop();
for(var i=0;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];
}
}
}
简陋效果图:
实例版:
思路:
若有五张图片:图1~5的left值分别为:20px、60px、100px、240px、380px;
点击左切换按钮后,对应的图1~5left值变为:60px、100px、240px、380px、20px;
--------------------------------------------------------------------------------
相当于这组数组第一个元素移到最后:20px、60px、100px、240px、380px、20px;
然后再把第一个元素删除得:60px、100px、240px、380px、20px;
以此类推:
实例布局:
Box">
实例样式:
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代码:
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.οnclick=function(){//右
arr.unshift(arr[arr.length-1]);
arr.pop();
for(var i=0;i
var oImg=aLi[i].getElementsByTagName('img')[0];
startMove(aLi[i],});
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];
}
}
}
效果图:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。
总结
以上是编程之家为你收集整理的灵活使用数组制作图片切换js实现全部内容,希望文章能够帮你解决灵活使用数组制作图片切换js实现所遇到的程序开发问题。
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
小编个人微信号 jb51ccc
喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!