数组元素位置变换:
将内容分割为数组,将第一个加到最后,删掉第一个
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];
}
}
}
简陋效果图:
实例版:
--------------------------------------------------------------------------------
相当于这组数组第一个元素移到最后:20px、60px、100px、240px、380px、20px; 然后再把第一个元素删除得:60px、100px、240px、380px、20px; 以此类推:
实例布局:
实例样式:
JS代码:
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];
}
}
}
效果图: