無縫滾動改進版支持上下左右滾動(封裝成函數(shù))
更新時間:2012年12月04日 15:53:48 作者:
無縫滾動改進版,封裝成函數(shù),同時支持上下左右無縫滾動。
復(fù)制代碼 代碼如下:
<!DOCTYPE HTML>
<html lang="en-US">
<head>
<meta charset="UTF-8">
<title>無縫滾動——上下</title>
<style type="text/css">
*{margin:0;padding:0;}
li{list-style:none;}
img{border:0;}
#scroll{width:178px;margin:50px auto;position:relative;}
.btn{display:block;width:27px;height:27px;position:absolute;left:75px;}
.up{background:url(images/up.gif);top:0;}
.down{background:url(images/down.gif);top:490px;}
.content{height:440px;overflow:hidden;position:relative;top:40px;}
.content ul{position:absolute;top:0;left:0;}
.content li{height:110px;}
</style>
</head>
<body>
<div id="scroll">
<a href="javascript:;" class="btn up"></a>
<a href="javascript:;" class="btn down"></a>
<div class="content">
<ul>
<li><a href="#" title="111"><img src="images/1.jpg" alt="111" width="178" height="108"/></a></li>
<li><a href="#" title="222"><img src="images/2.jpg" alt="222" width="178" height="108"/></a></li>
<li><a href="#" title="333"><img src="images/3.jpg" alt="333" width="178" height="108"/></a></li>
<li><a href="#" title="444"><img src="images/4.jpg" alt="444" width="178" height="108"/></a></li>
</ul>
</div>
</div>
</body>
</html>
<script type="text/javascript" src="scroll.js"></script>
<script type="text/javascript">
window.onload = function(){
scroll('top',1,1000);
};
</script>
scroll.js:
復(fù)制代碼 代碼如下:
/**********
功能:實現(xiàn)水平或垂直無縫滾動
參數(shù):direction方向,總共4個值:left,right,top,bottom
speed移動距離
iTime多少時間后開始移動,若不寫則頁面加載完開始移動
**********/
function scroll(direction,speed,iTime){
var oDiv = document.getElementById('scroll');
var oUl = oDiv.getElementsByTagName('ul')[0];
var aLi = oDiv.getElementsByTagName('li');
var aBtn = oDiv.getElementsByTagName('a');
var timer = null;
var iSpeed = 0;
var flag = true; //判斷水平移動還是垂直移動
oUl.innerHTML += oUl.innerHTML;
switch(direction){
case 'left':
iSpeed = -speed;
oUl.style.width = aLi[0].offsetWidth * aLi.length + 'px';
flag = true;
break;
case 'right':
iSpeed = speed;
oUl.style.width = aLi[0].offsetWidth * aLi.length + 'px';
flag = true;
break;
case 'top':
iSpeed = -speed;
flag = false;
break;
case 'bottom':
iSpeed = speed;
flag = false;
break;
};
setTimeout(move,iTime);
//左按鈕和上按鈕
aBtn[0].onclick = function(){
clearInterval(timer);
iSpeed = -speed;
move();
};
//右按鈕和下按鈕
aBtn[1].onclick = function(){
clearInterval(timer);
iSpeed = speed;
move();
};
oUl.onmouseover = function(){
clearInterval(timer);
};
oUl.onmouseout = function(){
move();
};
function move(){
timer = setInterval(function(){
if(flag){
oUl.style.left = oUl.offsetLeft + iSpeed + 'px';
if(oUl.offsetLeft < -oUl.offsetWidth / 2){
oUl.style.left = '0';
}else if(oUl.offsetLeft > 0){
oUl.style.left = - oUl.offsetWidth / 2 + 'px';
}
}else{
oUl.style.top = oUl.offsetTop + iSpeed + 'px';
if(oUl.offsetTop <= - oUl.offsetHeight / 2){
oUl.style.top = '0';
}else if(oUl.offsetTop >= 0){
oUl.style.top = - oUl.offsetHeight / 2 + 'px';
};
};
},30);
};
};
需要注意的是:html 結(jié)構(gòu)必須要像上面的結(jié)構(gòu)一樣。
相關(guān)文章
c#和Javascript操作同一json對象的實現(xiàn)代碼
剛開始學(xué)Javascript,接觸到j(luò)son對象,json可以看作是用于客戶端數(shù)據(jù)實體對象的載體。json對象一般都是通過ajax方式傳送給服務(wù)層2012-01-01javascript表單驗證使用示例(javascript驗證郵箱)
JavaScript可用來在數(shù)據(jù)被送往服務(wù)器前對HTML表單中的這些輸入數(shù)據(jù)進行驗證2014-01-01javascript 函數(shù)的暫停和恢復(fù)實例詳解
這篇文章主要介紹了javascript 函數(shù)的暫停和恢復(fù),結(jié)合實例形式詳細分析了javascript 函數(shù)的暫停和恢復(fù)相關(guān)原理、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下2020-04-04from表單多個按鈕提交用onclick跳轉(zhuǎn)不同action
這篇文章主要介紹了from表單多個按鈕提交用onclick跳轉(zhuǎn)不同action,需要的朋友可以參考下2014-04-04javascript框架設(shè)計讀書筆記之?dāng)?shù)組的擴展與修復(fù)
本文是司徒正美的《javascript框架設(shè)計》的第三章第2節(jié)的讀書筆記,本節(jié)主要介紹的是javascript數(shù)組的擴展與修復(fù),本文則是選取了其中的重點部分展示給大家。2014-12-12