asp 字幕连续滚动代码

求段asp字幕连续滚动不要添加插件的方法头部接尾部滚动JS的也行有方法的或参考的帮忙发个谢谢... 求段asp 字幕连续滚动 不要添加插件的方法 头部接尾部滚动 JS的也行 有方法的或参考的帮忙发个 谢谢 展开
 我来答
匿名用户
2013-09-25
展开全部
无缝滚动是使用JS实现的,其原理很简单将要滚动的Div平铺在父Div中,使用JS控制父DIv的滚动 Object.scrollLeft(向左) = Object.scrollLeft+滚动距离一定的时间间隔滚动一次当滚动距离 = 要滚动DIv的大小的时间,让父Div的 Object.scrollLeft回复到0,开始新一轮的滚动,这样就实现的无缝滚动,依上原理写出实例:<!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">
<!--
#marquee {
height: 120px;
width: 480px;
overflow: hidden;
}
#marquee .mi {
font-size: 12px;
width: 250px;
height: 110px;
border: 5px solid #666666;
margin-right: 10px;
margin-left: 10px;
}-->
</style>
<script type="text/javascript">
var marqueeInterval;
var cw,ch,mBody;
function marquee(){
try{
var A = arguments[0];
var O = document.getElementById(arguments[0])
var direction = arguments[1];
var delay = parseInt(arguments[2]);
var amount = parseInt(arguments[3]);
var isFirist = arguments[4];
var dw = O.offsetWidth
var dh = O.offsetHeight;
if(direction == "left" || direction == "right"){
clearInterval(marqueeInterval);
if(isFirist == true){
var mChild = document.all ? O.childNodes[0] : O.getElementsByTagName("div")[0];
cw = mChild.scrollWidth;
ch = mChild.scrollHeight;
//cw = document.all ? mChild.scrollWidth : mChild.clientWidth;
//ch = document.all ? mChild.scrollHeight : mChild.clientHeight;
mBody = mChild.innerHTML;
O.innerHTML = "";
var childNum = parseInt(dw/cw)+2;
var htmlString = "<table border=\"0\" width="+(childNum*cw)+" cellpadding=\"0\" cellspacing=\"0\"><tr>";
for(i = 0 ; i < childNum ; i++){
htmlString += "<td width=\""+cw+"\" height=\""+ch+"\"><div style=\"width:"+cw+"px height:"+ch+"px \">"+mBody+"</div></td>";
}
htmlString += "</tr></table>";
O.innerHTML = htmlString;
isFirist = false;
}
if(parseInt(O.scrollLeft) < parseInt(cw)){
O.scrollLeft = O.scrollLeft+amount;
}else{
O.scrollLeft = 0;
}
marqueeInterval = setInterval(function(){marquee(A,direction,delay,amount,isFirist)},delay)
}
}catch(e){
if (e.number == -2146827864)
alert("未选择要滚动的DIV")
else{
alert(e.description)
}
}
}
window.onload = function(){
marquee("marquee","left",50,1,true)
}
</script>
</head><body>
<div id="marquee" >
<div style="width: 240px;height: 18px;"><div class="mi">大家好,我是骄阳,这是一个无缝滚动效果</div></div>
</div>
<marquee direction="left" scrolldelay="10" scrollamount="1" width="480">大家好,我是骄阳,这是marquee的滚动效果</marquee>
</body>
</html>
由于时间问题,我只给你写一向左滚动效果但我还是建议你不要使用JS控制的无缝滚动,因为在WEB中setInterval和setTimeout都是很耗内存的这样就会降低你的页面执行速度如果你实在要用滚动效果的话,可以考虑用Flash代替
匿名用户
2013-09-25
展开全部
YYl里的 ? YY里的我有
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式