javascript 列表定时滚动效果
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:
javascript 列表定时滚动效果的更多相关文章
- 使用JavaScript实现新闻滚动效果
最近要实现一个滚动新闻效果,在网上查了一些资料,发现基本的实现方法有两种: 使用Marquee标签.这个标签的使用我已经转载了一篇比较详细的文章,这个标签的优点是便于使用,缺点是人们已经逐渐不适用它了 ...
- Javascript实现信息滚动效果的方法
<html><head><meta http-equiv="Content-Type" content="text/html; charse ...
- js实现的新闻列表垂直滚动实现详解
js实现的新闻列表垂直滚动实现详解:新闻列表垂直滚动效果在大量的网站都有应用,有点自然是不言而喻的,首先由于网页的空间有限,使用滚动代码可以使用最小的空间提供更多的信息量,还有让网页有了动态的效果,更 ...
- JavaScript实现页面滚动到div区域div以动画方式出现
用JavaScript实现页面滚动效果,以及用wow.js二种方式实现网页滚动效果 要实现效果是页面滚动到一块区域,该区域以动画方式出现. 这个效果需要二点: 一:我们要先写好一个css动画. 二:用 ...
- 二、JavaScript语言--JS实践--信息滚动效果制作
运用JavaScript技术,掌握无缝滚动和歇间性滚动的制作方法. 一.marquee标签实现信息滚动 1 behavior滚动的方式 alternate:表示在两端之间来回滚动 scroll:表示由 ...
- html+css+javascript实现列表循环滚动示例代码
使用html+css+javascript实现列表循环滚动,设置时间定时,在规定的时间内替换前一个节点的内容,具体示例如下,感兴趣的朋友可以参考下 说明:设置时间定时,在规定的时间内替换前一个节点的内 ...
- jQuery练手:仿新浪微博图片文字列表淡进淡出上下滚动效果
1.效果及功能说明 仿新浪微博图片文字列表上下淡进淡出间歇上下滚动 2.实现原理 首先要设定div内只能显示4个图片那么多出来的图片会自动隐藏然后在给图片添加一个动画的事件让他们可以滚动的播放出来上下 ...
- JavaScript js无间断滚动效果 scrollLeft方法 使用模板
JavaScript js无间断滚动效果 scrollLeft方法 使用模板 <!DOCTYPE HTML><html><head><meta charset ...
- JavaScript实现的购物车效果-效果好友列表
JavaScript实现的购物车效果.当然,可以在许多地方使用这种效果.朋友的.例如,在选择.人力资源模块,工资的计算,人才选拔等..下面来看一下班似有些车效果图: watermark/2/text/ ...
随机推荐
- hibernate框架学习之一级缓存
l缓存是存储数据的临时空间,减少从数据库中查询数据的次数 lHibernate中提供有两种缓存机制 •一级缓存(Hibernate自身携带) •二级缓存(使用外部技术) lHibernate的一级缓存 ...
- hibernate框架学习之核心配置文件
hibernate.cfg.xml <?xml version='1.0' encoding='utf-8'?> <!DOCTYPE hibernate-configuration ...
- PHP随机红包算法
2017年1月14日 14:19:14 星期六 一, 整体设计 算法有很多种, 可以自行选择, 主要的"架构" 是这样的, 用redis decr()命令去限流, 用mysql去记 ...
- RocketMQ实战快速入门
转自:https://www.jianshu.com/p/824066d70da8 一.RocketMQ 是什么 Github 上关于 RocketMQ 的介绍:RcoketMQ 是一款低延 ...
- [MySQL]join的细节
left join,左表返回所有记录,右表只返回跟左表有关联的记录,当右表有N条记录跟左表的某一条记录A关联,那么查询结果会出现N条A记录(相应关联右表的N条记录) right join,右表返回所有 ...
- VUE 浏览器关闭时清空localStorage
1. 概述 1.1 说明 vue项目中,为了解决页面刷新时vuex数据丢失问题,使用localStorage进行存储对应的vuex数据(判断对应localStorage是否为空,不为空则为vuex中数 ...
- 44)django-环境变量设置
如果外面程序需要调用django,就需要设置django环境指明调用那个项目. # _*_ coding:utf-8 _*_ __author__ = "shisanjun" im ...
- WebRequest使用(车)
// 待请求的地址 string url = "http://www.cnblogs.com"; // 创建 WebRequest 对象,WebRequest 是抽象类,定义了请求 ...
- Confluence 6 "Duplicate Key" 相关问题解决
如果你遇到了下面的错误信息,例如: could not insert: [bucket.user.propertyset.BucketPropertySetItem#bucket.user.prope ...
- PHP之十六个魔术方法
1.__construct,__destruct__constuct构建对象的时被调用:__destruct明确销毁对象或脚本结束时被调用:2.__get,__set__set当给不可访问或不存在属性 ...