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. SharePoint 2016: 数据库正在兼容性范围内运行,建议进行升级

    问题描述: SharePoint 运行状况分析器提示: 中文:数据库正在兼容性范围内运行,建议进行升级. 英文:Database running in compatibility range and ...

  2. git与eclipse集成之clone远程仓库到本地

    1. Git与Eclipse集成 1.1. Clone远程仓库到本地 1.1.1.        获取远程仓库地址(选择北京,访问速度比深圳快) 1.1.2.        将远程仓库导入到Eclip ...

  3. Lyk Love painting/convex hull/mumsic

    这场比赛真的是...打的好颓废啊... 所有题面的传送门 T1 分析: 我们发现 二分答案 + \(n^3\) \(dp\) 判断可行性 可以拿 60 分(于是就写好了啊!) 然后我们发现上面的 \( ...

  4. <第一站>人生的第一个博客

    在畅畅的疯狂暗示下(“最好”建个博客),我决定在博客园开通我的博客,在此记入我从3月23起的所学所想.在他的提醒之前,我曾经断断续续的在日记本上,手机备忘录里记录过我的学习情况和心路历程,总的来说,自 ...

  5. Linux下怎样搜索文件

    使用linux系统难免会忘记文件所在的位置,可以使用以下命令对系统中的文件进行搜索.搜索文件的命令为”find“:”locate“:”whereis“:”which“:”type“   方法/步骤   ...

  6. Python学习 --- 列表

    list 函数可以将 序列变为列表 列表操作: 1 . 元素赋值, 根据索引,可以直接修改 2 . 删除元素, del x[i] 3 . 分片赋值, name[1:] = list (' '), 可以 ...

  7. MySQL按字段排序后取序号

    1 前言 项目中排行榜刚好需要查数据库表然后给出编号,方案一,可以按条件查找出来,然后再按数组序号给编号,但是如果要查表出来直接看,就不太够用了:方案二,就是用代码帮忙编号.参考了网上一些代码,然后发 ...

  8. ActiveMQ-为什么需要消息中间件?

    消息中间件的优势 UNIX的进程间通信就开始运用消息队列技术,一个进程将数据写入某个特定的队列中,其它进程可以读取队列中的数据,从而实现异步通信.对于如今的分布式系统,消息队列已经演变为独立的消息中间 ...

  9. javaweb web.xml文件详解

    web.xml文件详解 前言:一般的web工程中都会用到web.xml,web.xml主要用来配置,可以方便的开发web工程.web.xml主要用来配置Filter.Listener.Servlet等 ...

  10. Confluence 6 通过 SSL 或 HTTPS 运行

    Atlassian 应用可以通过 HTTPS 进行访问,但是 Atlassian 并不提供有关访问的支持服务,同时 Atlassian 不能保证能够提供所有的支持. 如果你的 assistance 在 ...