HTML结构:

<div style="width:200px;height:100px;overflow:hidden;border:1px solid #ddd;margin:20px auto;">
<ul id="list">
<li><a href="#">2222222222222222222222222</a></li>
<li><a href="#">3333333333333333333333333</a></li>
<li><a href="#">22222222222222222222222222</a></li>
<li><a href="#">22222222222223222222222222</a></li>
<li><a href="#">22222222222222422222222222</a></li>
<li><a href="#">2222222222222252222222222</a></li>
<li><a href="#">22222222225555552222222222</a></li>
<li><a href="#">22222222222253333333222222</a></li>
<li><a href="#">22222222277777777222222</a></li>
</ul>
</div>

js:

 /*
* 列表定时滚动效果(javascript)
* @listId :滚动列表ID
* @listTagName :滚动元素
* @scrollNum :设置滚动元素数量
* @speed : 滚动速度
*/
function fnScrollList(){
this.init.apply(this,arguments);
}
fnScrollList.prototype = {
init:function(listId,TagName,scrollNum,speed){
var _this = this;
this.oList = this.$$(listId);
this.scrollTimer = null;
this.speed = speed || 1000;
this.scrollNum = scrollNum || 1;
this.TagName =TagName;
this.distance = this.oList.getElementsByTagName(TagName)[0].offsetHeight * this.scrollNum;//列表移动距离
this.oList.style.marginTop = 0 + "px"; this.oList.onmouseover = function(){
_this.pause();
}
this.oList.onmouseout = function(){
_this.scrollTimer= setTimeout(function(){
_this.play();
},_this.speed);
}
this.play();
},
play:function(){
var _this = this;
var options = {'marginTop':'-'+_this.distance};
_this.anim(_this.oList,options,function(){ //回调函数,移动列表元素
for(var i = 0,j = 0;i<_this.scrollNum;i++){
var node = _this.oList.getElementsByTagName(_this.TagName)[j];
if(_this.TagName == "tr"){
_this.oList.getElementsByTagName('tbody')[0].appendChild(node);
}else{
_this.oList.appendChild(node);
}
}
_this.oList.style.marginTop = "0px";
}); _this.scrollTimer= setTimeout(function(){
_this.play(_this.distance);
},_this.speed);
},
pause:function(){
clearTimeout(this.scrollTimer);
},
//动画函数
anim:function(oElement,oAttr,fnCallback){
var _this = this;
clearInterval(oElement.timer);
oElement.timer = setInterval(function(){
var bStop = true;
for(var property in oAttr){
var iCur = parseFloat(_this.css(oElement, property)); //获取当前位置属性值
var iSpeed = (oAttr[property] - iCur) / 5; //移动进度
iSpeed = iSpeed > 0 ? Math.ceil(iSpeed) : Math.floor(iSpeed);
if (iCur != oAttr[property]) { //如果当前数值不等于目标数值,则数值递增
bStop = false;
_this.css(oElement, property, iCur + iSpeed);
}
}
if(bStop){
clearInterval(oElement.timer);
fnCallback && fnCallback.apply(_this, arguments);
}
},50);
},
//处理样式函数
css:function(oElement, attr, value){
if (arguments.length == 2) {
return oElement.currentStyle ? oElement.currentStyle[attr] : getComputedStyle(oElement, null)[attr];
} else if (arguments.length == 3) {
switch (attr) {
case "top":
case "left":
case "marginTop":
oElement.style[attr] = value + "px";
break;
default:
oElement.style[attr] = value;
break;
}
}
},
$$:function(o){
if(o){
return document.getElementById(o);
}
}
};

函数调用:

var list = new fnScrollList('list','li',2,2000);

效果:

站点名称 AQI 类别
工业园区1 123 轻度污染
工业园区2 123 轻度污染
工业园区3 123 轻度污染
工业园区4 123 轻度污染
工业园区5 123 轻度污染
工业园区6 123 轻度污染
工业园区7 123 轻度污染
工业园区8 123 轻度污染

demo:

demo.zip

javascript 列表定时滚动效果的更多相关文章

  1. 使用JavaScript实现新闻滚动效果

    最近要实现一个滚动新闻效果,在网上查了一些资料,发现基本的实现方法有两种: 使用Marquee标签.这个标签的使用我已经转载了一篇比较详细的文章,这个标签的优点是便于使用,缺点是人们已经逐渐不适用它了 ...

  2. Javascript实现信息滚动效果的方法

    <html><head><meta http-equiv="Content-Type" content="text/html; charse ...

  3. js实现的新闻列表垂直滚动实现详解

    js实现的新闻列表垂直滚动实现详解:新闻列表垂直滚动效果在大量的网站都有应用,有点自然是不言而喻的,首先由于网页的空间有限,使用滚动代码可以使用最小的空间提供更多的信息量,还有让网页有了动态的效果,更 ...

  4. JavaScript实现页面滚动到div区域div以动画方式出现

    用JavaScript实现页面滚动效果,以及用wow.js二种方式实现网页滚动效果 要实现效果是页面滚动到一块区域,该区域以动画方式出现. 这个效果需要二点: 一:我们要先写好一个css动画. 二:用 ...

  5. 二、JavaScript语言--JS实践--信息滚动效果制作

    运用JavaScript技术,掌握无缝滚动和歇间性滚动的制作方法. 一.marquee标签实现信息滚动 1 behavior滚动的方式 alternate:表示在两端之间来回滚动 scroll:表示由 ...

  6. html+css+javascript实现列表循环滚动示例代码

    使用html+css+javascript实现列表循环滚动,设置时间定时,在规定的时间内替换前一个节点的内容,具体示例如下,感兴趣的朋友可以参考下 说明:设置时间定时,在规定的时间内替换前一个节点的内 ...

  7. jQuery练手:仿新浪微博图片文字列表淡进淡出上下滚动效果

    1.效果及功能说明 仿新浪微博图片文字列表上下淡进淡出间歇上下滚动 2.实现原理 首先要设定div内只能显示4个图片那么多出来的图片会自动隐藏然后在给图片添加一个动画的事件让他们可以滚动的播放出来上下 ...

  8. JavaScript js无间断滚动效果 scrollLeft方法 使用模板

    JavaScript js无间断滚动效果 scrollLeft方法 使用模板 <!DOCTYPE HTML><html><head><meta charset ...

  9. JavaScript实现的购物车效果-效果好友列表

    JavaScript实现的购物车效果.当然,可以在许多地方使用这种效果.朋友的.例如,在选择.人力资源模块,工资的计算,人才选拔等..下面来看一下班似有些车效果图: watermark/2/text/ ...

随机推荐

  1. win32编程中消息循环和WndProc()窗口过程函数

    原文地址:https://blog.csdn.net/zxxSsdsd/article/details/45504383 在win32程序的消息循环函数中  while (GetMessage (&a ...

  2. Debian下undefined reference to ‘pthread_create’问题解决

    今天在写线程测试程序(pthread_create)时出现如下问题, 明明在头文件中包含了<pthread.h>,但是仍然提示找不到函数 pthread_create 和 pthread_ ...

  3. T-SQL GROUP BY子句 分组查询

    SQL Server GROUP BY子句与SELECT语句协作使用,以将相同的数据分组. GROUP BY子句位于SELECT语句中的WHERE子句之后,位于ORDER BY子句之前. 语法 以下是 ...

  4. LightOJ1004

    #include<bits/stdc++.h> using namespace std; int Map[106][106]; int Vis[106][106]; int Num[106 ...

  5. POJ 1305

    毕达哥斯三元组的模板题 练习练习 #include<iostream> #include<cstring> #include<cstdio> #include< ...

  6. ElasticSearch搜索数据到底有几种方式?

    Elasticsearch允许三种方式执行搜索请求: GET请求正文: curl -XGET "http://localhost:9200/app/users/_search" - ...

  7. IntelliJ IDEA插件 - ApiDebugger

    IntelliJ IDEA插件 - ApiDebuggerApiDebugger,是一个开源的接口调试IntelliJ IDEA插件,具有与IDEA一致的界面,无需切换程序即可完成网络API请求,让你 ...

  8. Confluence 6 设置 Oracle 数据库准备

    请查看 Supported Platforms 页面来获得 Confluence 系统支持的 Oracle 数据库版本.你需要在安装 Confluence 之前升级你的 Oracle 数据库. 如果你 ...

  9. 利用map和stringstream数据流解题

    题目描述 喜闻乐见A+B.读入两个用英文表示的A和B,计算它们的和并输出. 输入 第一行输入一个字符串,表示数字A:第二行输入一个字符串表示数字B.A和B均为正整数. 输出 输出一个正整数n,表示A+ ...

  10. Python if __name__ == '__main__':(以主程序形式执行)

    在外部调用某个模块时,可能会将只能在本模块执行的代码给执行了,有没有什么办法让某些特定的代码指定只能在自身运行时才执行被调用时不执行呢?使用if __name__ == '__main__':. 示例 ...