JS图片无缝上下滚动


  在网站制作的过程中难免会遇到运用图片或者文字滚动的时候,作为一个后台程序员,最重要的一点就是收集整理代码,用的时候就很方便。今天给大家分享一种简易的js实现marquee图片文字无缝滚动代码,这些代码都是本人在用的。如果有什么问题可以联系我。代码如下:
       <style type="text/css">
    <!-- 首先定义好css样式:

    #demo {
    background: #FFF;
    overflow:hidden;
    border: 1px dashed #CCC;
    height: 100px;
    text-align: center;
    float: left;
    }
    #demo img {
    border: 3px solid #F2F2F2;
    display: block;
    }
    -->
    </style>
    向上滚动
    <div id="demo">
    <div id="demo1">
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
   <a href="#"><img src="#" border="0" /></a>
    </div>
    <div id="demo2"></div>
    </div>
    <script>
    <!--
    var speed=10; //数字越大速度越慢
    var tab=document.getElementById("demo");
    var tab1=document.getElementById("demo1");
    var tab2=document.getElementById("demo2");
    tab2.innerHTML=tab1.innerHTML; //克隆demo1为demo2
    function Marquee(){
    if(tab2.offsetTop-tab.scrollTop<=0)//当滚动至demo1与demo2交界时
    tab.scrollTop-=tab1.offsetHeight //demo跳到最顶端
    else{
    tab.scrollTop++
    }
    }
    var MyMar=setInterval(Marquee,speed);
    tab.οnmοuseοver=function() {clearInterval(MyMar)};//鼠标移上时清除定时器达到滚动停止的目的
    tab.οnmοuseοut=function() {MyMar=setInterval(Marquee,speed)};//鼠标移开时重设定时器
    -->
    </script>
    ------------------------------------------------------------
    图片向下无缝滚动只需要改变一下js代码即可
    <script>
    <!--
    var speed=10; //数字越大速度越慢
    var tab=document.getElementById("demo");
    var tab1=document.getElementById("demo1");
    var tab2=document.getElementById("demo2");
    tab2.innerHTML=tab1.innerHTML; //克隆demo1为demo2
    tab.scrollTop=tab.scrollHeight
    function Marquee(){
    if(tab1.offsetTop-tab.scrollTop>=0)//当滚动至demo1与demo2交界时
    tab.scrollTop+=tab2.offsetHeight //demo跳到最顶端
    else{
    tab.scrollTop--
    }
    }
    var MyMar=setInterval(Marquee,speed);
    tab.οnmοuseοver=function() {clearInterval(MyMar)};//鼠标移上时清除定时器达到滚动停止的目的
    tab.οnmοuseοut=function() {MyMar=setInterval(Marquee,speed)};//鼠标移开时重设定时器
    -->
    </script>
上面两段js代码一对比,看出端倪来了吗?原来就是一个运算的问题。tab.scrollTop+=tab2.offsetHeight ; tab.scrollTop++ 这个是向上,tab.scrollTop-=tab2.offsetHeight ; tab.scrollTop-- 这个是乡下。
  *****************************************************************************************************
   图片向左无缝滚动
    <style type="text/css">
    <!--
    #demo {
           background: #FFF;overflow:hidden;border: 1px dashed #CCC;width: 500px;
          }
    #demo img {
           border: 3px solid #F2F2F2;
               }
    #indemo {
           float: left; width: 800%;
            }
    #demo1 { float: left; }
    #demo2 {
    float: left;
           }
    -->
    </style>
    向左滚动
    <div id="demo">
    <div id="indemo">
    <div id="demo1">
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    <a href="#"><img src="#" border="0" /></a>
    </div>
    <div id="demo2"></div>
    </div>
    </div>
    <script>
    <!--
    var speed=10; //数字越大速度越慢
    var tab=document.getElementById("demo");
    var tab1=document.getElementById("demo1");
    var tab2=document.getElementById("demo2");
    tab2.innerHTML=tab1.innerHTML;
    function Marquee(){
    if(tab2.offsetWidth-tab.scrollLeft<=0)
    tab.scrollLeft-=tab1.offsetWidth
    else{
    tab.scrollLeft++;
        }
    }
    var MyMar=setInterval(Marquee,speed);
    tab.οnmοuseοver=function() {clearInterval(MyMar)};
    tab.οnmοuseοut=function() {MyMar=setInterval(Marquee,speed)};
    -->
    </script>
    ------------------------------------------------------
    图片向右无缝滚动
    <script>
    <!--
    var speed=10; //数字越大速度越慢
    var tab=document.getElementById("demo");
    var tab1=document.getElementById("demo1");
    var tab2=document.getElementById("demo2");
    tab2.innerHTML=tab1.innerHTML;
    function Marquee(){
    if(tab.scrollLeft<=0)
    tab.scrollLeft+=tab2.offsetWidth
    else{
    tab.scrollLeft--;
    }
    }
    var MyMar=setInterval(Marquee,speed);
    tab.οnmοuseοver=function() {clearInterval(MyMar)};
    tab.οnmοuseοut=function() {MyMar=setInterval(Marquee,speed)};
    -->
    </script>
    上面两段js代码一对比,看出端倪来了吗?原来也是一个运算的问题。tab.scrollTop+=tab2.offsetHeight ; tab.scrollTop++ 这个是向左,tab.scrollTop-=tab2.offsetHeight ; tab.scrollTop-- 这个是向右。
     现在问题出来了,我要是想制作向左和向右或者是向上或者向下应该怎么做呢?这个问题很简单。只要添加两个按钮,把上面的几个js分别集合成函数,在按钮的onclick或者是onmouseover事件上调用即可。不要担心兼容性问题,经过测试兼容现在的各大浏览器。如果以上有什么问题,请指出修正。
 
本文来源于本文转自贝斯特SEO http://www.028best.com/ , 原文地址:http://www.028best.com/wzjs/17.html


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值