js實(shí)現(xiàn)單張圖片平移切換效果
本文參考了JQuery實(shí)現(xiàn)圖片切換(自動(dòng)切換+手動(dòng)切換)
由于個(gè)人不需要手動(dòng)切換功能,因此把那部分的內(nèi)容刪了,主要是增加了無縫切換的效果。
原理也很簡單,大概是一張圖移動(dòng)到左邊以后,從底部移回最右,等待下一次循環(huán)。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="js/jquery-1.10.1.min.js"></script>
</head>
<body>
<div class="wrapper">
<h1>jquer實(shí)現(xiàn)圖片切換</h1>
<div id="focus">
<ul>
<!-- 這里有三個(gè)z-index的設(shè)置 -->
<li><div class="switch_pic" style="z-index: 3;background: url('imgs/01.jpg') center center;background-size: cover;"></div></li>
<li><div class="switch_pic" style="z-index: 2;background: url('imgs/02.jpg') center center;background-size: cover;"></div></li>
<li><div class="switch_pic" style="z-index: 1;background: url('imgs/03.jpg') center center;background-size: cover;"></div></li>
<li><div class="switch_pic" style="background: url('imgs/04.jpg') center center;background-size: cover;"></div></li>
<li><div class="switch_pic" style="background: url('imgs/meiko2.jpg') center center;background-size: cover;"></div></li>
<li><div class="switch_pic" style="background: url('imgs/meiko7.jpg') center center;background-size: cover;"></div></li>
</ul>
</div>
</div>
<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); //網(wǎng)頁打開立即執(zhí)行一次動(dòng)畫
picTimer = setInterval(function() {
index++;
if(index == len) {index = 0;}
showPics(index);
},3000);//3000毫秒的間隔
//顯示圖片函數(shù),根據(jù)接收的index值顯示相應(yīng)的內(nèi)容
function showPics(index) { //普通切換
var nowLeft = -sWidth; //每次移動(dòng)固定量
var $pic = $pics.eq(index);//獲取當(dāng)前要移出的圖片
var $nexPic = $pics.eq((index+1)%len);//當(dāng)前要移入的圖片
var $nexnexPic = $pics.eq((index+2)%len);//下一個(gè)要移入的圖片
$nexPic.css("left",sWidth);//下一個(gè)圖片移動(dòng)到最右
//當(dāng)前要移出的圖片開始左移,模式設(shè)為平滑"linear",速度和間隔一樣
$pic.animate({"left":nowLeft},3000,"linear",function(){
// 當(dāng)前圖片完全移出后,重新設(shè)置z-index
$pic.css("z-index",1);
$nexPic.css("z-index",3);
$nexnexPic.css("z-index",2);
});
//當(dāng)前要移入的圖片同時(shí)左移
$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 div{position:absolute;overflow:hidden;width: 450px;height: 350px;}
</style>
</body>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
layui表格設(shè)計(jì)以及數(shù)據(jù)初始化詳解
今天小編就為大家分享一篇layui表格設(shè)計(jì)以及數(shù)據(jù)初始化詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10
js實(shí)現(xiàn)的驗(yàn)證,學(xué)習(xí)用js控制td
JS日積月累001 - rows 和 cells的使用2008-12-12
js實(shí)現(xiàn)一個(gè)簡易計(jì)算器
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)一個(gè)簡易計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
javaScript 計(jì)算兩個(gè)日期的天數(shù)相差(示例代碼)
本篇文章主要介紹了javaScript 計(jì)算兩個(gè)日期的天數(shù)相差(示例代碼) 需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-12-12

