停顿滚动

原创 2007年09月21日 13:30:00

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
<style type="text/css">
<!--
.STYLE4 { color: #FF0000;
 font-weight: bold;
}

#pscroller2{
width: 1000px;
height: 30px;
border: 1px solid black;
padding: 3px;
}

body {
 background-color: #000000;
}
-->
</style>

<script type="text/javascript">

/***********************************************
* Pausing up-down scroller- ? Dynamic Drive (www.dynamicdrive.com)
* This notice MUST stay intact for legal use
* Visit http://www.dynamicdrive.com/ for this script and 100s more.
***********************************************/

function pausescroller(content, divId, divClass, delay){
 this.content=content //message array content
 this.tickerid=divId //ID of ticker div to display information
 this.delay=delay //Delay between msg change, in miliseconds.
 this.mouseoverBol=0 //Boolean to indicate whether mouse is currently over scroller (and pause it if it is)
 this.hiddendivpointer=1 //index of message array for hidden div
 document.write('<div id="'+divId+'" class="'+divClass+'" style="position: relative; overflow: hidden"><div class="innerDiv" style="position: absolute; width: 100%" id="'+divId+'1">'+content[0]+'</div><div class="innerDiv" style="position: absolute; width: 100%; visibility: hidden" id="'+divId+'2">'+content[1]+'</div></div>')
 var scrollerinstance=this
 if (window.addEventListener) //run onload in DOM2 browsers
  window.addEventListener("load", function(){scrollerinstance.initialize()}, false)
 else if (window.attachEvent) //run onload in IE5.5+
  window.attachEvent("onload", function(){scrollerinstance.initialize()})
 else if (document.getElementById) //if legacy DOM browsers, just start scroller after 0.5 sec
 setTimeout(function(){scrollerinstance.initialize()}, 500)
}

// -------------------------------------------------------------------
// initialize()- Initialize scroller method.
// -Get div objects, set initial positions, start up down animation
// -------------------------------------------------------------------

pausescroller.prototype.initialize=function(){
 this.tickerdiv=document.getElementById(this.tickerid)
 this.visiblediv=document.getElementById(this.tickerid+"1")
 this.hiddendiv=this.hiddendiv=document.getElementById(this.tickerid+"2")
 this.visibledivtop=parseInt(pausescroller.getCSSpadding(this.tickerdiv))
 //set width of inner DIVs to outer DIV's width minus padding (padding assumed to be top padding x 2)
 this.visiblediv.style.width=this.hiddendiv.style.width=this.tickerdiv.offsetWidth-(this.visibledivtop*2)+"px"
 this.getinline(this.visiblediv, this.hiddendiv)
 this.hiddendiv.style.visibility="visible"
 var scrollerinstance=this
 this.tickerdiv.onmouseover=function(){scrollerinstance.mouseoverBol=1}
 this.tickerdiv.onmouseout=function(){scrollerinstance.mouseoverBol=0}
 setTimeout(function(){scrollerinstance.animateup()}, this.delay)
}


// -------------------------------------------------------------------
// animateup()- Move the two inner divs of the scroller up and in sync
// -------------------------------------------------------------------

pausescroller.prototype.animateup=function(){
 var scrollerinstance=this
 if (parseInt(this.hiddendiv.style.top)>(this.visibledivtop+5)){
  this.visiblediv.style.top=parseInt(this.visiblediv.style.top)-5+"px"
  this.hiddendiv.style.top=parseInt(this.hiddendiv.style.top)-5+"px"
  setTimeout(function(){scrollerinstance.animateup()}, 50)
 }else{
  this.getinline(this.hiddendiv, this.visiblediv)
  this.swapdivs()
  setTimeout(function(){scrollerinstance.setmessage()}, this.delay)
 }
}

// -------------------------------------------------------------------
// swapdivs()- Swap between which is the visible and which is the hidden div
// -------------------------------------------------------------------

pausescroller.prototype.swapdivs=function(){
 var tempcontainer=this.visiblediv
 this.visiblediv=this.hiddendiv
 this.hiddendiv=tempcontainer
}

pausescroller.prototype.getinline=function(div1, div2){
 div1.style.top=this.visibledivtop+"px"
 div2.style.top=Math.max(div1.parentNode.offsetHeight, div1.offsetHeight)+"px"
}

// -------------------------------------------------------------------
// setmessage()- Populate the hidden div with the next message before it's visible
// -------------------------------------------------------------------

pausescroller.prototype.setmessage=function(){
 var scrollerinstance=this
 if (this.mouseoverBol==1) //if mouse is currently over scoller, do nothing (pause it)
  setTimeout(function(){scrollerinstance.setmessage()}, 100)
 else{
  var i=this.hiddendivpointer
  var ceiling=this.content.length
  this.hiddendivpointer=(i+1>ceiling-1)? 0 : i+1
  this.hiddendiv.innerHTML=this.content[this.hiddendivpointer]
  this.animateup()
 }
}

pausescroller.getCSSpadding=function(tickerobj){ //get CSS padding value, if any
 if (tickerobj.currentStyle)
  return tickerobj.currentStyle["paddingTop"]
 else if (window.getComputedStyle) //if DOM2
  return window.getComputedStyle(tickerobj, "").getPropertyValue("padding-top")
 else
  return 0
}

</script>

</head>

<body>
 
<script type="text/javascript">

/*Example message arrays for the two demo scrollers*/

var pausecontent2=new Array()
pausecontent2[0]='省行通知:基金净值'
pausecontent2[1]='某某分行公告:基金净值 '

</script>
<script type="text/javascript">

//new pausescroller(name_of_message_array, CSS_ID, CSS_classname, pause_in_miliseconds)

new pausescroller(pausecontent2, "pscroller2", "STYLE4", 6000)

</script>
</body>
</html>
 

使用jquery实现的循环连续可停顿滚动

使用jquery实现的循环连续可停顿滚动,并应用于滚动图片,滚动层。记得一定要有jquery库哦~ 一、单行滚动    [xhtml] view plain copy ...
  • sbyygyrgw555
  • sbyygyrgw555
  • 2016年08月25日 11:17
  • 1289

JS-文字上下滚动(多行停顿)

JS-文字上下滚动(多行停顿)
  • yangyisen0713
  • yangyisen0713
  • 2015年09月09日 14:16
  • 682

JVM 调优 —— GC 长时间停顿问题及解决方法

零. 简介 垃圾收集器长时间停顿,表现在 Web 页面上可能是页面响应码 500 之类的服务器错误问题,如果是个支付过程可能会导致支付失败,将造成公司的直接经济损失,程序员要尽量避免或者说减少此类情...
  • wenniuwuren
  • wenniuwuren
  • 2016年04月12日 11:42
  • 4524

javascript实现列表有停顿循环滚动

无间隙循环滚动 body { font-size: 12px; line-height: 24px; text-algin: center; /* 页...
  • LIUMINGM900913
  • LIUMINGM900913
  • 2014年10月08日 20:45
  • 609

最简单的banner真无限循环滑动(无缝衔接版)

大家好,本次带来一个超级简单的真!无限循环滑动viewpager,注意哦!!是真循环,而且超级简单,起码比我在网上搜到了一些同样功能的写法要简单的多!OK  切入正题; 有人会问,什么是真循环...
  • qq_22956223
  • qq_22956223
  • 2015年05月28日 13:51
  • 1874

Animation插值器:解决Android Animation 循环执行的停顿问题

在Android开发中,有时候我们需要一个动画一直循环执行下去,常见的如laoding菊花一直旋转,这时候就需要使用Animation的repeat功能,如下: animation = new Ro...
  • chzphoenix
  • chzphoenix
  • 2017年12月01日 17:28
  • 84

JavaScript 无缝上下左右滚动加定高定宽停顿效果

转载:http://www.cnblogs.com/cloudgamer/archive/2008/04/30/1177682.html 根据无缝滚动和八向滚动修改而来,特点是能同一程序...
  • csdn1339906034
  • csdn1339906034
  • 2017年03月24日 17:56
  • 100

《对Java的分析总结》-Java中的垃圾回收器的类型概述 (六)

Only those who attempt the absurd can achieve the impossible
  • zl18603543572
  • zl18603543572
  • 2015年05月27日 19:32
  • 403

在Solr4.10配置IKAnalyzer 同义词、扩展词库、停顿词详解

在配置IKAnalyzer 同义词时,遇到一些麻烦,配置了半天终于成功,在此做个记录,方便以后参考 其实配置也简单,主要是jar包,IKAnalyzer貌似已经没人更新了……本人也是从别人那下载的才可...
  • tjcyjd
  • tjcyjd
  • 2015年02月10日 10:46
  • 16263

Java自动内存管理机制(四) 垃圾收集算法

概述先介绍几种基础经典算法及其思想1. 标记-清除算法
  • u012440687
  • u012440687
  • 2016年07月26日 15:05
  • 302
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:停顿滚动
举报原因:
原因补充:

(最多只允许输入30个字)