本文主要为大家详细介绍了js实现单张图片平移切换效果,一张图移动到左边以后,从底部移回最右,等待下一次循环,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。
本文参考了jquery实现图片切换(自动切换+手动切换)
由于个人不需要手动切换功能,因此把那部分的内容删了,主要是增加了无缝切换的效果。
原理也很简单,大概是一张图移动到左边以后,从底部移回最右,等待下一次循环。
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<script src="js/jquery-1.10.1.min.js"></script>
</head>
<body>
<p class="wrapper">
<h1>jquer实现图片切换</h1>
<p id="focus">
<ul>
<!-- 这里有三个z-index的设置 -->
<li><p class="switch_pic" style="z-index: 3;background: url('imgs/01.jpg') center center;background-size: cover;"></p></li>
<li><p class="switch_pic" style="z-index: 2;background: url('imgs/02.jpg') center center;background-size: cover;"></p></li>
<li><p class="switch_pic" style="z-index: 1;background: url('imgs/03.jpg') center center;background-size: cover;"></p></li>
<li><p class="switch_pic" style="background: url('imgs/04.jpg') center center;background-size: cover;"></p></li>
<li><p class="switch_pic" style="background: url('imgs/meiko2.jpg') center center;background-size: cover;"></p></li>
<li><p class="switch_pic" style="background: url('imgs/meiko7.jpg') center center;background-size: cover;"></p></li>
</ul>
</p>
</p>
<script type="text/javascript">
$(function() {
var swidth = $("#focus").width();
var len = $("#focus ul li").length;
var index = 0;
var pictimer;
var $pics = $("#focus ul li").find('.switch_pic');//获取所有图片
showpics(index); //网页打开立即执行一次动画
pictimer = setinterval(function() {
index++;
if(index == len) {index = 0;}
showpics(index);
},3000);//3000毫秒的间隔
//显示图片函数,根据接收的index值显示相应的内容
function showpics(index) { //普通切换
var nowleft = -swidth; //每次移动固定量
var $pic = $pics.eq(index);//获取当前要移出的图片
var $nexpic = $pics.eq((index+1)%len);//当前要移入的图片
var $nexnexpic = $pics.eq((index+2)%len);//下一个要移入的图片
$nexpic.css("left",swidth);//下一个图片移动到最右
//当前要移出的图片开始左移,模式设为平滑"linear",速度和间隔一样
$pic.animate({"left":nowleft},3000,"linear",function(){
// 当前图片完全移出后,重新设置z-index
$pic.css("z-index",1);
$nexpic.css("z-index",3);
$nexnexpic.css("z-index",2);
});
//当前要移入的图片同时左移
$nexpic.animate({"left":0},3000,"linear");
}
});
</script>
<style type="text/css">
*{margin:0;padding:0;}
body{font-size:12px;color:#222;font-family:verdana,arial,helvetica,sans-serif;background:#f0f0f0;}
.clearfix:after{content: ".";display: block;height: 0;clear: both;visibility: hidden;}
.clearfix{zoom:1;}
ul,li{list-style:none;}
img{border:0;}
.wrapper{width:800px;margin:0 auto;padding-bottom:50px;}
h1{height:50px;line-height:50px;font-size:22px;font-weight:normal;font-family:"microsoft yahei",simhei;margin-bottom:20px;}
#focus{width:450px;height:350px;overflow:hidden;position:relative;}
#focus ul{height:380px;position:absolute;}
#focus ul li{float:left;width:450px;height:350px;overflow:hidden;position:absolute;background:#000;}
#focus ul li p{position:absolute;overflow:hidden;width: 450px;height: 350px;}
</style>
</body>
相关推荐:
javascript实现鼠标滚轮控制页面图片切换功能示例
实例详解jquery自动或手动图片切换效果
javascript实现鼠标滚轮控制页面图片切换的示例代码
利用javascript制作图片切换的方法介绍
简单实现javascript图片切换效果
以上就是js单张图片平移切换效果实例分享的详细内容。