js吧html中的图片改为数组图片,灵活使用数组制作图片切换js实现

灵活使用数组制作图片切换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];

}

}

}

简陋效果图:

2016072817073165.gif

实例版:

思路:

若有五张图片:图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">

1.png

1.jpg

2.jpg

3.jpg

1.jpg

实例样式:

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

喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用JavaScript和CSS来实现网页图片的轮转切换: 1. 首先,你需要在HTML创建一个包含图片的容器,例如div元素。 2. 在CSS,你需要设置容器的宽度和高度,并将其图片设置为绝对定位,以便它们可以在容器移动。 3. 接下来,你可以创建一个JavaScript函数来实现轮转切换。该函数应该接受一个参数,即要显示的下一张图片的索引。在函数内部,你可以使用CSS的transform属性来移动当前显示的图片,并将下一张图片移动到可见区域。 4. 最后,你可以使用setInterval函数来定期调用该函数,以便自动轮转图片。 下面是一个简单的示例代码,可以帮助你入门: HTML: ```html <div id="image-container"> <img src="image1.jpg" class="active"> <img src="image2.jpg"> <img src="image3.jpg"> </div> ``` CSS: ```css #image-container { position: relative; width: 500px; height: 300px; } #image-container img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; opacity: 0; transition: opacity 1s ease-in-out; } #image-container img.active { opacity: 1; } ``` JavaScript: ```javascript var currentIndex = 0; var images = document.querySelectorAll('#image-container img'); var intervalId = setInterval(changeImage, 3000); function changeImage() { currentIndex = (currentIndex + 1) % images.length; images[currentIndex].classList.add('active'); images[currentIndex - 1].classList.remove('active'); } ``` 在这个示例,我们首先定义了一个变量currentIndex来跟踪当前显示的图片的索引。然后,我们使用document.querySelectorAll函数选择所有的图片元素,并将它们存储在一个名为images的数组。接下来,我们使用setInterval函数每3秒钟调用一次changeImage函数。该函数使用currentIndex变量来确定要显示的下一张图片的索引,并使用classList.add和classList.remove方法来添加和删除“active”类,以便将当前显示的图片和下一张图片的透明度进行切换。 请注意,这只是一个简单的示例,可以根据你的需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值