javascript实现图片无缝滚动(scrollLeft的使用方法介绍)

<!DOCTYPE html >

<html>

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>无标题文档</title>

<style>

.piczhanshi{width:976px;height:167px;border:1px #999999 solid;margin:0 auto;}

h3{

float:left;

background-color: #DDD;

float: left;

height: 35px;

width: 966px;

margin-top: 2px;

line-height: 35px;

text-align: center;

color: #064278;

font-size: 18px;

margin-left: 5px;

margin-right: 5px;

margin-bottom: 10px;

}

.tupian{

float:left;

width:966px;

height:120px;

margin-left:5px;margin-right:5px;

}

.demo{width:966px;height:110px;overflow:hidden;margin-top:5px;margin-bottom:5px;} //这个是scrollLeft作用的层,实现移动效果的是他的子级divindexmo

#indemo{width:800%;height:110px;} //这里的宽度为他的父级div层的8倍宽

.demo1,.demo2{float:left;}

</style>

</head>

<body>

<div id="piczhanshi" class="piczhanshi">

<h3>鸟巢效果图</h3>

<div id="tupian" class="tupian">//这里是包括图片的最外层div是为了定位而设置的与滚动没关系

<div id="demo" class="demo">   // 这里是包括图片的div,也就是须要实现子级div滚动的层(scrollLeft是相对于当前层的子层的),这里必须这是好宽高已经overflow:hidden

<div id="indemo">  //这个是须要滚动的图片包括层,他的宽度在图片左右滚动效果下,比他的父级div的宽大,这里设置为800%,也就是相当他的父级div来说,他等于父级div宽的8倍

<div id="demo1" class="demo1">//这里是包括图片的层,通过“float”和demo2实现无缝连接

<img src="image/niaochao1.jpg" />

<img src="image/niaochao2.jpg" />

<img src="image/niaochao3.jpg" />

<img src="image/niaochao4.jpg" />

<img src="image/niaochao5.jpg" />

<img src="image/niaochao6.jpg" />

<img src="image/niaochao7.jpg" />

<img src="image/niaochao8.jpg" />

<img src="image/niaochao9.jpg" />

</div>

<div id="demo2" class="demo2"></div>//这里通过js代码“ tab2.innerHTML=tab1.innerHTML;”得到demo1的值,通过“float”和demo1实现无缝连接

</div>

</div>

</div>

</div>

<script language="javascript">

var speed=20;

var tab=document.getElementById("demo");

var tab1=document.getElementById("demo1");

var tab2=document.getElementById("demo2");

tab2.innerHTML=tab1.innerHTML; //通过赋值获得tab1的值

function marquee(){

if(tab2.offsetWidth-tab.scrollLeft<=0)//当tab的移动宽度大于等于demo1的时候,scrollLeft为0,也就是恢复到未移动前的情况,继续移动

{tab.scrollLeft=0}

else

{tab.scrollLeft++;} //图片层不断的往left移动

}

var timer=setInterval(marquee,speed); //定时器

tab.onmouseover=function(){clearInterval(timer)};//鼠标经过容器的时候清除定时器

tab.onmouseout=function(){timer=setInterval(marquee,speed);}//鼠标移开容器的时候開始定时器

</script>

</body>

</html>

*******************2004-04-26,优化后,点击左右的图片就清除自己主动滚动的定时器,实现点击的时候能够滚动对应的像素************************

<!DOCTYPE html >

<html >

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>无标题文档</title>

<style>

.main{width:980px;height:190px;border:1px #999999 solid;margin:0 auto;}

h3{width:980px;height:30px;text-align:center;color:#3399FF;float:left;}

.tupian{width:980px;height:139px;float:left;position:relative;}

.indemo{width:800%;height:139px;}

.demo{width:948px;height:160px;float:left;overflow:hidden;}

.demo1{float:left;}

.demo2{float:left;}

.right{height:89px;width:16px;left:0;margin-top:40px;float:left;}

.left{height:89px;width:16px;margin-top:40px;float:left;}

</style>

</head>

<body>

<div id="main" class="main">

<h3>鸟巢展示图</h3>

<div id="tupian" class="tupian">

<div class="left"><img src="images/but_l2.jpg" class="lt" id="lt" /></div>

<div id="demo" class="demo">

<div id="indemo" class="indemo">

<div id="demo1" class="demo1">

<img src="images/niaochao1.jpg" />

<img src="images/niaochao2.jpg" />

<img src="images/niaochao3.jpg" />

<img src="images/niaochao4.jpg" />

<img src="images/niaochao5.jpg" />

<img src="images/niaochao6.jpg" />

<img src="images/niaochao7.jpg" />

<img src="images/niaochao8.jpg" />

<img src="images/niaochao9.jpg" />

</div>

<div id="demo2" class="demo2"></div>

</div>

</div>

<div class="right"><img src="images/but_r2.jpg" class="rt" id="rt" /></div>

</div>

</div>

<script type="text/javascript">

var speed=20;

var tab=document.getElementById("demo");

var tab1=document.getElementById("demo1");

var tab2=document.getElementById("demo2");

var lt=document.getElementById("lt");

var rt=document.getElementById("rt");

tab2.innerHTML=tab1.innerHTML;

function marquee(){

if(tab2.offsetWidth-tab.scrollLeft<=0)

{tab.scrollLeft=0}

else

{tab.scrollLeft++;}

}

var timer=setInterval(marquee,speed);

tab.onmouseover=function(){clearInterval(timer)};

tab.onmouseout=function(){timer=setInterval(marquee,speed)}

rt.onmouseout=function(){timer=setInterval(marquee,speed)};
//由于设置了点击图标的的时候清除定时器,所以这里必须在移开鼠标的时候開始定时器

lt.onmouseout=function(){timer=setInterval(marquee,speed)};

lt.onclick=function(){      //点击左图标时候执行

clearInterval(timer);   //清除定时器

if(tab.scrollLeft>=1440){tab.scrollLeft=0;}  //当层往左移动的像素大于1440的时候,scrillLeft返回0

else{tab.scrollLeft+=160} //不断的往左滚

}

rt.onclick=function(){ //点击右边鼠标的时候

clearInterval(timer);//清除定时器

if(tab.scrollLeft==0){tab.scrollLeft=1440;} //scroll为0的时候(这里必须注意,if里面是用“==”,是对照的意思,{}里面的“=”是赋值的意思,不能弄混),scrollLeft返回0

else if(tab.scrollLeft<=-1440){tab.scrollLeft=0;}//当scrollLeft少于1440的时候,scrollLeft返回0,同一时候)if(){}         else{}之间是不存在不论什么标记符号的,这是格式

else{tab.scrollLeft-=160;}

}

</script>

</body>

</html>

javascript实现图片无缝滚动(scrollLeft的使用方法介绍)

时间: 2024-10-10 13:02:09

javascript实现图片无缝滚动(scrollLeft的使用方法介绍)的相关文章

javascript实现图片无缝滚动-------Day 27

今天感冒变严重了,鼻涕止不住啊,一卷卫生纸就这样报废了,还是不想吃药,熬熬总能熬过去吧,状态不是很好,看这么个小应用竟然看了很久的时间,到最后才像猛的明白了一样,而且查着好像有好几种做法的,今天先说说这种吧,比较好理解额. 所谓"图片无缝滚动",我们可以这样来理解,如果只用marquee,则需要尾部也离开容器了,头部才能从头部另一端出现,重新进行滚动,如是进行循环,而无缝滚动,就是说一种首尾相连的效果,头部是咬在尾部上的,尾部全部漏出来后,后面紧挨着显示头部的部分,这样首尾相连进行的滚

JavaScript学习笔记5 之 计时器 &amp; scroll、offset、client系列属性 &amp; 图片无缝滚动

一.计时器 setInterval ( 函数/名称 , 毫秒数 )表示每经过一定的毫秒后,执行一次相应的函数(重复) setTimeout ( 函数/名称 , 毫秒数 ) 表示经过一定的毫秒后,只执行一次相应的函数(不重复) 清除计时器: clearInterval( ); clearTimeout( ); 当计时器调用执行完毕时,它将返回一个timer ID, 如果将该ID传递给clearInterval,便可以终止代码的执行. 实例: 页面布局: <div id="wrap"

jquery图片无缝滚动特效

jquery图片无缝滚动插件制作左右无缝滚动图片和上下无缝滚动图片,一款简单的jQuery无缝滚动代码.JS代码 <script type="text/javascript"> //图片滚动 调用方法 imgscroll({speed: 30,amount: 1,dir: "up"}); $.fn.imgscroll = function(o){ var defaults = { speed: 40, amount: 0, width: 1, dir:

jquery图片无缝滚动代码左右 上下无缝滚动图片

<!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-

第41天:匀速、缓动运动和图片无缝滚动

一.匀速运动和缓动运动 缓动运动公式:leader=leader+(target-leader)/10;//leader为初始值0,target为结束值,10可以改变,值越大,速度越慢 1 <!DOCTYPE html> 2 <html lang="en"> 3 <head> 4 <meta charset="UTF-8"> 5 <title>运动</title> 6 <style>

原生javascript效果:无缝滚动

<style type="text/css"> #con {width:400px; padding:10px; margin:20px auto; text-align:center; border:1px solid #ccc;} #con .roll {width:400px; height:100px; position:relative; overflow:hidden; margin-bottom:10px;} #con ul {position:absolut

js多组图片无缝滚动

原文:js多组图片无缝滚动 源代码下载地址:http://www.zuidaima.com/share/1550463717608448.htm

Javascript图片无缝滚动

js无缝滚动效果几乎在任何网页上都能看到它的身影,有的可能是使用插件,其实使用原始的javascript比较简单. 主要的是使用js位置知识. 1.innerHTML:设置或获取元素的html标签 2.scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距 3.offsetWidth:设置或获取指定标签的宽度 4.setInterval():设置方法定时启动 5.clearInterval();清除定时器 效果图: 先睹为快:demo <!DOCTYPE html>

JavaScript----marquee滚动标签 图片无缝滚动 插入百度地图

页面的自动滚动效果,可由javascript来实现, 但是有一个html标签 - <marquee></marquee>可以实现多种滚动效果,无需js控制. 使用marquee标记不仅可以移动文字,也可以移动图片,表格等. 语法:<marquee>...</marquee>: 说明:在标记之间添加要进行滚动的内容. 重要属性: 1.滚动方向direction(包括4个值:up. down. left和 right) 语法:<marquee direct