jQuery 圖片垂直切換效果詳解

admin發表於2018-12-18

圖片垂直切換在很多網頁中都有應用。

下面是一個比較簡單的程式碼例項,下面對它實現過程進行一下詳細介紹。

程式碼例項如下:

[HTML] 純文字檢視 複製程式碼執行程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
#main{
  border:5px #666 solid; 
  width:500px; 
  height:350px; 
  overflow:hidden;
}
#box div{
  width:500px; 
  height:350px;
  line-height:350px;
  text-align:center;
}
</style>
<script type="text/javascript" src="mytest/jQuery/jquery-1.8.3.js"></script>
<script type="text/javascript"> 
$(document).ready(function(){ 
  var Top=-350;
  var Time=500;
  function move(){ 
    $("#box").animate({"margin-top":Top},Time);
    Top+=-350;
    if(Top==-1050){ 
      Top=0;
    } 
  } 
  setInterval(move,3000);
}) 
</script>
</head>
<body>
<div id="main">
  <div id="box">
    <div style="background-color:#0F0;">螞蟻部落一</div>
    <div style="background-color:#00F;">螞蟻部落二</div>
    <div style="background-color:#696;">螞蟻部落三</div>
  </div>
</div>
</body>
</html>

上程式碼實現了向上滾動效果,這裡的圖片以背景色替代了,如果實際應用在div中加上圖片即可。

一.實現原理:

原理非常的簡單,每隔指定的時間設定一次box元素的margin-top屬性值,每一次設定的幅度大小恰好是box元素下div的高度,這樣就實現了向上滾動效果。當top的值等於-1050的時候,也就是第三個div展現的時候,再將top重置為零,下一次函式的執行,那麼又會將box的margin-top設定為0,這樣又將開始新的一輪的迴圈。

二.程式碼註釋:

(1).$(document).ready(function(){}),當穩當結構完全載入完畢再去執行函式中的程式碼。

(2).var Top=-350,宣告一個變數並賦值為-350,用以設定box的margin-top屬性值。

(3).var Time=500,宣告一個變數並賦值為500,用以設定向上滾動的速度。

(4).function move(),此函式是實現滾動的核心。

(5).$("#box").animate({"margin-top":Top},Time),以動畫方式設定box的margin-top屬性值。

(6).Top+=-350,top值在每次執行一次move函式就減去350,350恰好是box下div的高度。

(7).if(Top==-1050),當top值等於-1050的時候將會把top值重置為0.

(8).setInterval(move,3000),每隔3秒鐘呼叫一次move函式。

三.相關閱讀:

(1).animate()函式可以參閱jQuery animate()一章節。

(2).setInterval()函式可以參閱setInterval()用法一章節。

相關文章