按鈕能夠控制的JS橫向圖片滾動

      一個JavaScript圖片滾動效果,與其它不一樣的區別是,它是能夠被控制的,向左向右滾動都須要點擊兩端的小箭頭,圖片滾動時候帶有緩衝效果,演示圖片沒有加連接,你決定用了就好好完善它,如今只是一個基礎的框架,也沒有怎麼美化,請注意,JavaScript代碼必定要放在調用圖片的代碼以後,不然會失效。javascript

 

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>JS橫向圖片滾動</title>
<style>
ul{margin:0;padding:0;list-style:none;width:100000px}
li{margin:0;padding:0;width:100px;height:90px;display:block;float:left;margin-right:5px;background:#009900}
#img_bag{width:640px;height:90px;background:#FF9900;margin:0 auto;font-size:9pt;}
#img_bag a{float:left;width:20px;display:block;height:20px;font-weight:bold;}
#img_bag #img{width:600px;height:90px;background:#ccc;overflow:hidden;float:left;border:0px;}
#scrollBar{width:600px;height:20px;background:#FF0000;margin:0 auto;position:relative}
#scroll{width:30px;height:20px;background:#000000;cursor:pointer;position:absolute;}
</style>
</head>
<body>
<div id="img_bag">
<a href="javascript:void(0)" onmousedown="moveLeft()"><<</a>
<div id="img">
<ul>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s9.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s2.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s3.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
<li><img src="/jscss/demoimg/wall_s1.jpg"></li>
</ul>
</div>
<a href="javascript:void(0)" onmousedown="moveRight()">>></a>
</div>
<div style="clear:both;"></div>
<div id="scrollBar"><div id="scroll" style="left:0"></div></div>
<script>
function $(obj){return document.getElementById(obj)}
var maxWidth=$("img").getElementsByTagName("ul")[0].getElementsByTagName("li").length*105;
var isScroll=false;
var modiLeft;
$("scroll").onmousedown=function(evt){
isScroll=true;
evt=(evt)?evt:((window.event)?window.event:null);
if(evt.offsetX){
modiLeft=parseInt(evt.offsetX)
}
else{modiLeft=parseInt(evt.layerX)}
}
document.onmouseup=function(){
isScroll=false;
}
document.onmousemove=function(evt){
evt=(evt)?evt:((window.event)?window.event:null);
if(evt&&isScroll){
$("scroll").style.left=parseInt(evt.clientX)-parseInt($("scrollBar").offsetLeft)-modiLeft+"px";
if(parseInt($("scroll").style.left)<0){$("scroll").style.left=0+"px"}
if(parseInt($("scroll").style.left)>570){$("scroll").style.left=570+"px"}
$("img").scrollLeft=parseInt($("scroll").style.left)*((maxWidth-600)/570);
  }
}
var targetx = 200;//一次滾動距離
var dx;
var a=null;
function moveLeft(){
var le=parseInt($("img").scrollLeft);
if(le>200){
targetx=parseInt($("img").scrollLeft)-200;
}
else{targetx=parseInt($("img").scrollLeft)-le-1}
scLeft();
}
function scLeft(){
dx=parseInt($("img").scrollLeft)-targetx;
$("img").scrollLeft-=dx*.3;
$("scroll").style.left=parseInt($("img").scrollLeft)*(570/(maxWidth-600))+"px";
if(parseInt($("scroll").style.left)<0){$("scroll").style.left=0+"px"}
if(parseInt($("scroll").style.left)>570){$("scroll").style.left=570+"px"}
clearScroll=setTimeout(scLeft,50);
if(dx*.3<1){clearTimeout(clearScroll)}
}
function moveRight(){
var le=parseInt($("img").scrollLeft)+200;
var maxL=maxWidth-600;
if(le<maxL){
targetx=parseInt($("img").scrollLeft)+200;
}
else{targetx=maxL}
scRight();
}
function scRight(){
dx=targetx-parseInt($("img").scrollLeft);
$("img").scrollLeft+=dx*.3;
$("scroll").style.left=parseInt($("img").scrollLeft)*(573/(maxWidth-600))+"px";
if(parseInt($("scroll").style.left)<0){$("scroll").style.left=0+"px"}
if(parseInt($("scroll").style.left)>=570){$("scroll").style.left=570+"px"}
a=setTimeout(scRight,50);
if(dx*.3<1){clearTimeout(a)}
}
</script>
</body>
</html>css

相關文章
相關標籤/搜索