Ø  前言

其实,前面两篇已经基本上实现了图片、文字跑马灯,这里为什么还要学下文字左右跑马灯呢?因为,虽然基本一样,但实现起来还是有很大不同的,所以为了完整再补充一下。代码如下:

1.   首先定义 css 样式

#div1 {

width: 500px;

height: 50px;

border: 1px solid black;

margin: 100px auto;

/*overflow: hidden;*/

position: relative;

}

.div {

width: 288px;

height: 30px;

line-height: 30px;

margin: auto;

position: absolute;

left: 0;

top: 0;

display: inline-block;

border: 1px solid blue;

}

2.   HTML 代码

<div id="div1">

<div class="div">我是一段文字,用于实现跑马灯功能~</div>

<div class="div">我也是一段文字,用于实现跑马灯功能~</div>

<!--<div class="div">我还是一段文字,用于实现跑马灯功能~</div>-->

</div>

3.   JS 代码

function $(str) { return (document.getElementById(str)); }

var div1;   //外层div元素

window.onload = function() {

init();

div1.start();

}

//设置当前滚动元素的 left、top 值

function move(x, y) {

this.style.left = x + 'px';

this.style.top = y + 'px';

}

//重置当前滚动元素

function reset() {

var p = this.parentNode;

this.move(p.offsetWidth, (p.offsetHeight - 2 - this.offsetHeight) / 2);

}

//初始化

function init() {

div1 = $("div1");

div1.currentIndex = 0;          //当前滚动元素索引

div1.loopItems = new Array();   //所有的滚动元素数组

div1.timer = null;              //计时器Id

div1.speed = 1;                 //速度值

div1.delay = 10;                //下一项延迟时间

div1.start = start;

div1.startLoop = startLoop;

div1.stopLoop = stopLoop;

div1.onmouseout = function() { this.startLoop(); }

div1.onmouseover = function() { this.stopLoop(); }

var divs = div1.getElementsByTagName("div");

//设置所有元素,并加入数组中

for(var i = 0; i < divs.length; i++) {

divs[i].index = i;

divs[i].move = move;

divs[i].reset = reset;

div1.loopItems.push(divs[i]);

}

}

//开始

function start() {

for(var i = 0; i < this.loopItems.length; i++) {

this.loopItems[i].reset();

}

this.startLoop();

}

//开始滚动

function startLoop() {

clearTimeout(this.timer);

if(this.currentIndex >= this.loopItems.length)

this.currentIndex = 0;

var div = this.loopItems[this.currentIndex];

//首先左移

if(div.offsetLeft > 0 - div.offsetWidth) {

div.move(div.offsetLeft - this.speed, div.offsetTop);

} else if(div.offsetTop > 0 - div.offsetHeight) {   //再上移

div.move(div.offsetLeft, div.offsetTop - this.speed);

} else {  //最后重置元素

div.reset();

this.currentIndex++;

}

this.timer = setTimeout('$("' + this.id + '").startLoop();', this.delay);

}

//停止滚动

function stopLoop() {

clearTimeout(this.timer);

}

4.   运行效果

Ø  知识点梳理

1.   首先定义了 $ 的全局函数,用于根据指定的元素 id 获取元素,是不是有点类似 jQuery ? 哈哈,不要被骗了,只支持 id 查找。

2.   因为元素是使用的 position: absolute;(绝对定位),所以可以使用 element.style.left = xx.px 来定位元素。

3.   无论是外层 div 或内部的移动 div 元素,都使用了将属性或方法直接赋值到元素的属性之上,这样在方法内部就可以直接使用 this 关键字访问到元素。

4.   使用 currentIndex 记录当前移动元素的索引,以及 loopItems 属性用于存储所有移动元素的数组,这样是一个比较合理的设计,视乎有点面向对象的感觉?

5.   在以上示例中,主要根据元素的 offsetLeft、offsetTop、offsetWidth、offsetHeight 等属性来定位移动元素的 left 和 top。

使用 JS 实现文字左右跑马灯的更多相关文章

  1. 使用 JS 实现文字上下跑马灯

    Ø  前言 今天在做商城首页时,遇到一个上下跑马灯功能,因为之前也只是接触过左右的跑马灯,一时还不知道从何下手.在网上看了几个 demo,并亲自运行了一下,是可以实现的.但是,能运行不知其所以然也不行 ...

  2. 使用 JS 实现图片左右跑马灯

    Ø  前言 之前写了一篇使用 JS 实现文字上下跑马灯,现在乘热打铁在把图片左右跑马灯一起贴出来,不多说直接看代码. 1.   首先定义 css 样式 <style type="tex ...

  3. CSS文字的跑马灯特效

    上学时同学有个来电带跑马灯的手机,可把我羡慕坏了,可等我买的起手机时,跑马灯不流行了,甚伤萝卜心! 今天就用CSS做个文字的跑马灯特效,缅怀一下本萝卜逝去的青春! 道具:会敲代码的巧手.七窍玲珑心.会 ...

  4. Unity3D 文字滚动跑马灯效果

    需求 在日常游戏中,文字滚动效果是比较常用的.例如日常游戏顶部的新闻公告,聊天系统的文字滚动,都属于这个范围. 思路 由于使用的地方比较广泛,所以希望能够尽量独立的游戏之外,能够做到随处使用的功能.N ...

  5. JS写一个列表跑马灯效果--基于touchslide.js

    先放上效果图: 类似于这样的,在列表中循环添加背景样式的跑马灯效果. 准备引入JS插件: <script type="text/javascript" src="x ...

  6. jquery.marquee.js - 有点奇怪的跑马灯动画,不过还是加上去了

    客户想要一个跑马灯的效果,最终我用了jquery.marquee.js. 这个库很简单就能用. 效果是这样,从左到右,移动速度都不一样. 1. HTML <div class="mar ...

  7. JavaScript实现文字跑马灯

    其实实现文字的跑马灯和实现图片轮播的原理是一样的. 下面是我自己实现的,文字的位置可以随便更改,效果不会变,文字的内容可以通过ajax获取,同时,可以直接用Jquery改写一下,很方便. <!D ...

  8. android使用TextView实现跑马灯的效果(1)

    android使用TextView实现跑马灯的效果 1.activity_main.xml <?xml version="1.0" encoding="utf-8& ...

  9. android实现跑马灯效果

    第一步:新建一个新项目,MarqueeTextView 首先为了观察到跑马灯效果,将要显示的文字极可能 写长.在strings.xml目录里面将 <string name="hello ...

随机推荐

  1. VSIX 插件右键菜单(2)

    编译项目然后发布 // 获取当前右击的活动项目 EnvDTE.Project activeProj = ProjectHelpers.GetActiveProject(); // 获取 编译选项 Re ...

  2. VC++2010组件安装失败解决办法

    安装SQLSERVER时,安装不上,总是报错说 VC++2010组件安装错误. 单独安装时,也会报出严重错误无法安装.就是下面这两个 最后到网上找到一个办法解决了:如下: 下载这个软件 Microso ...

  3. luogu3188/bzoj1190 梦幻岛宝珠 (分层背包dp)

    他都告诉你能拆了 那就拆呗.把每个重量拆成$a*2^b$的形式 然后对于每个不同的b,先分开做30个背包 再设f[i][j]表示b<=i的物品中 容量为$ j*2^i+W\&((1< ...

  4. Palindrome Function HDU - 6156(数位dp)

    要求m-n内在l-r进制下的是回文数的总个数. dp[进制][从第j为开始][目前到达第k位] = 总的方案数 dfs枚举目前的到达的位置,这个数开始的位置,进制,前导零,限制条件,然后枚举的时候如果 ...

  5. HEOI2016解题报告

    树 在2016年,佳媛姐姐刚刚学习了树,非常开心.现在他想解决这样一个问题:给定一颗有根树(根为1),有以下 两种操作:1. 标记操作:对某个结点打上标记(在最开始,只有结点1有标记,其他结点均无标记 ...

  6. 定时自动从FTP服务器取数据脚本

    环境需求:某些情况下经常需要向FTP服务器取文件,可以用定时任务执行简单脚本自动去取相应文件. 一般用法: ~]# ftp  IP地址  端口 //ftp命令可以通过yum install ftp方式 ...

  7. poj 3186 Treats for the Cows(dp)

    Description FJ has purchased N (1 <= N <= 2000) yummy treats for the cows who get money for gi ...

  8. kvm虚拟化管理

    虚拟化 KVM (kernel-based virtual machine) 常见的一些虚拟化的软件xen kvm vmware esx openVZ Oracle VM VirtualBox vsp ...

  9. 使用Disruptor实现生产者和消费者模型

    生产者 package cn.lonecloud.procum.disruptor; import cn.lonecloud.procum.Data; import com.lmax.disrupto ...

  10. css预编译语言sass——mixin的使用

    以根据不同屏幕吃寸动态应用背景图片为例 新建一个mixin如下: @mixin bg_img($path, $ext){ @media screen and (max-device-width: 76 ...