<!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的使用方法介绍)的更多相关文章

  1. Javascript实现图片无缝滚动

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

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

    一.计时器 setInterval ( 函数/名称 , 毫秒数 )表示每经过一定的毫秒后,执行一次相应的函数(重复) setTimeout ( 函数/名称 , 毫秒数 ) 表示经过一定的毫秒后,只执行 ...

  3. 应用JavaScript搭建一个简易页面图片无缝滚动效果

    页面图片无缝滚动JavaScript原理:移动的区块包含图片内容,区块相对父级元素进行定位脱离文档流.再令区块的left值每隔固定的时间进行等量减少(或增大)从而实现区块的匀速运动.由于每次间隔移动的 ...

  4. jQuery图片无缝滚动JS代码ul/li结构

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. jQuery图片无缝滚动

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

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

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. CSS和jQuery分别实现图片无缝滚动效果

    一.效果图 二.使用CSS实现 <!DOCTYPE html> <html> <head> <meta charset="utf-8"&g ...

  8. 原生javascript效果:无缝滚动

    <style type="text/css"> #con {width:400px; padding:10px; margin:20px auto; text-alig ...

  9. Javascript获取图片原始宽度和高度的方法详解

    前言 网上关于利用Javascript获取图片原始宽度和高度的方法有很多,本文将再次给大家谈谈这个问题,或许会对一些人能有所帮助. 方法详解 页面中的img元素,想要获取它的原始尺寸,以宽度为例,可能 ...

随机推荐

  1. 分布式文件系统GlusterFS

    转自于:http://www.cnblogs.com/zitjubiz/archive/2012/11/30/Distributed_File_System_glusterFS.html Gluste ...

  2. 10个SQL注入工具(转载)

    众所周知,SQL注入攻击是最为常见的Web应用程序攻击技术.同时SQL注入攻击所带来的安全破坏也是不可弥补的.以下罗列的10款SQL注入工具可帮助管理员及时检测存在的漏洞. BSQL Hacker 1 ...

  3. Linux下安装yum工具

    Linux下安装yum工具 http://blog.csdn.net/caoshichaocaoshichao/article/details/13171919

  4. Excel VBA ——批量工作表重命名

    虽然平常在用excel 2010重命名工作表的时候,一般可能会用"双击工作表"的方法来重名,但是遇到大批量重名的时候就很麻烦. 我的方法,先建一张新表,然后在第一列写好要命名的表名 ...

  5. BZOJ 3373: [Usaco2004 Mar]Lying Livestock 说谎的牲畜( 差分约束 )

    枚举每头牛, 假设它在说谎, 建图判圈就行了...为啥水题都没人来写.. --------------------------------------------------------------- ...

  6. QList 和std::list的比较

    QList QList<T> 是一个Qt通用容器类.它存储一序列的值,并且提供基于索引的数据访问方法和快速的插入和删除操作. QList<T>, QLinkedList< ...

  7. mysql 监控 大批量的插入,删除,和修改

    监控大批量的插入,修改和删除: mysql> insert into aaa select * from aaa; mysql> SELECT trx_id, trx_state, trx ...

  8. mysql Emoji表情字符集转换

    <pre name="code" class="html">Java代码 java.sql.SQLException: Incorrect stri ...

  9. 【JSP】JSP与oracle数据库交互案例

    ************************************************************************ ****原文:blog.csdn.net/clark_ ...

  10. 认识到了x64程序的必要性

    假如我做一个程序,在运行过程中需要使用一个Map,然而这个Map存储了超多信息的话,系统内存不够就会崩溃了.以前的解决方案可能是把内容存储在一个文件/数据库里,但是有内存岂不是更方便.更直截了当!