zoukankan      html  css  js  c++  java
  • JS实现跑马灯效果(向左,向上)

    <html>
    <head>
    <title>JS实现跑马灯效果</title>
    <style>
    * {
        font-size:12px;
        font-family:宋体, Arial;
    } /*规定了所有的字体样式*/
    body {
        overflow:auto;
    }
    #mq {
        220px;
        height:40px;
        line-height:20px;
        overflow:hidden;
        border:1px solid black;
    }
    #mq div {
        position:absolute;
        220px;
        padding:0px 10px;
    }
    </style>
    <script>
    function init(){
        initMq($("mq"));
        $("mq").start();
    }
      
    function initMq(obj){
        var objs;
        //定义跑马灯对象的自定义属性
        obj.currentItem = -1;
        obj.loopDelay = 50;
        obj.loopItems = new Array();
        obj.loopTimer = null;
        obj.speedX = 2;
        obj.speedY = 2;
        //定义跑马灯对象的自定义方法
        obj.loop = mq_loop;
        obj.start = mq_startLoop;
        obj.stop = mq_stopLoop;
        //定义跑马灯对象的事件
        obj.onmouseover = function(){ this.stop(); }
        obj.onmouseout = function(){ this.loop(); }
         
        //获取跑马灯对象的所有子元素
        objs = obj.getElementsByTagName("div");
        for(var i=0; i<objs.length; i++){
            //在loopItems属性中记录子元素
            obj.loopItems.push(objs[i]);
            //自定义子元素的属性和方法
            objs[i].index = i;
            objs[i].move = move;
            objs[i].reset = mq_reset;
            //初始化子元素的状态
            objs[i].reset();
        }
    }
      
    function move(x, y){
        this.style.left = x + "px";
        this.style.top = y + "px";
    }
      
    function mq_loop(){
        var obj;
        clearTimeout(this.loopTimer);
        if(this.currentItem >= this.loopItems.length)this.currentItem = 0;
        obj = this.loopItems[this.currentItem];
        if(obj.offsetLeft!=this.offsetLeft){
            //向左卷动
            obj.move(obj.offsetLeft - this.speedX, obj.offsetTop);
        }else if(obj.offsetTop + obj.offsetHeight > this.offsetTop){
            //向上卷动
            obj.move(obj.offsetLeft, obj.offsetTop - this.speedX);
        }else{
            //重置该子元素
            obj.reset();
            this.currentItem++;
        }
        this.loopTimer = setTimeout("$(""+this.id+"").loop();", this.loopDelay);
    }
      
    function mq_reset(){
        var p = this.parentNode;
        this.move(p.offsetLeft + p.offsetWidth, p.offsetTop);
    }
      
    function mq_startLoop(){
        for(var i=0; i<this.loopItems.length; i++)this.loopItems[i].reset();
        this.currentItem = 0;
        this.loop();
    }
      
    function mq_stopLoop(){
        clearTimeout(this.loopTimer);
    }
      
    function $(str){ return(document.getElementById(str)); }
    window.onload = init;
    </script>
    </head>
    <body>
    <div id="mq">
      <div> js实现的跑马灯效果11111 </div>
      <div> js实现的跑马灯效果22222 </div>
    </div>
    </body>
    </html>
    

      转自:http://yuncode.net/code/c_50796e1da2e7863

  • 相关阅读:
    BZOJ3212 Pku3468 A Simple Problem with Integers(线段树区间求和、区间加模板)
    BZOJ2208 [Jsoi2010]连通数
    洛谷P3952 时间复杂度
    BZOJ1051 [HAOI2006]受欢迎的牛
    BZOJ4318 OSU!
    BZOJ1798 [Ahoi2009]Seq 维护序列
    BZOJ1483 [HNOI2009]梦幻布丁
    洛谷P1439 最长公共子序列(O(nlogn)最长公共子序列模板)
    BZOJ2429 [HAOI2006]聪明的猴子
    BZOJ3714 [PA2014]Kuglarz
  • 原文地址:https://www.cnblogs.com/laneyfu/p/7590820.html
Copyright © 2011-2022 走看看