<!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=utf-8" />
<title>多行滾動jQuery循環新聞列表代碼</title>
<style type="text/css">
*{margin:0;padding:0}
ul {list-style: none;}
#scrollDiv{width:800px;height:100px;min-height:25px;line-height:25px;border:#ccc 1px solid;overflow:hidden}
#scrollDiv li{height:25px;padding-left:10px;}
#scrollDiv ul:nth-child(1) {
margin-left: 20px;
float: left;
}
#scrollDiv ul:nth-child(2) {
margin-left: 10px;
float: left;
}
</style>
<script src="jquery.min.js" type="text/javascript"></script>
<script type="text/javascript">
//滾動插件
(function($){
$.fn.extend({
Scroll:function(opt,callback){
//參數初始化
if(!opt) var opt={};
var this_obj=this.find("ul");
var lineH=this.find("ul").eq(0).find("li:first").height(), //獲取行高
line=opt.line?parseInt(opt.line,10):parseInt(this_obj.parent("div").height()/lineH,10), //每次滾動的行數,默認爲一屏,即父容器高度
speed=opt.speed?parseInt(opt.speed,10):500, //捲動速度,數值越大,速度越慢(毫秒)
timer=opt.timer?parseInt(opt.timer,10):3000; //滾動的時間間隔(毫秒)
if(line==0) line=1;
var upHeight=0-line*lineH;
//滾動函數
marquee=function(this_obj){
this_obj.animate({
marginTop:upHeight
},speed,function(){
for(var j=1;j<=line;j++){
this_obj.find("li:first").appendTo(this_obj);
}
this_obj.css({marginTop:0});
});
}
//循環函數
scrollUp=function(){
for (var i=0;i<this_obj.length;i++){
var this_obj_son=this_obj.eq(i);
marquee(this_obj_son);
}
}
//鼠標事件綁定
this.hover(function(){
clearInterval(timerID);
},function(){
timerID=setInterval("scrollUp()",timer);
}).mouseout();
}
})
})(jQuery);
$(document).ready(function(){
$("#scrollDiv").Scroll({line:4,speed:2000,timer:2000});
});
</script>
</head>
<body>
<p>多行滾動演示:</p>
<div id="scrollDiv">
<ul>
<li>這是公告標題的第一行</li>
<li>這是公告標題的第二行</li>
<li>這是公告標題的第三行</li>
<li>這是公告標題的第四行</li>
<li>這是公告標題的第五行</li>
<li>這是公告標題的第六行</li>
<li>這是公告標題的第七行</li>
<li>這是公告標題的第八行</li>
<li>這是公告標題的第四行</li>
<li>這是公告標題的第五行</li>
<li>這是公告標題的第六行</li>
<li>這是公告標題的第七行</li>
<li>這是公告標題的第八行</li>
</ul>
<ul>
<li>這是公告標題的第1行</li>
<li>這是公告標題的第2行</li>
<li>這是公告標題的第3行</li>
<li>這是公告標題的第4行</li>
<li>這是公告標題的第5行</li>
<li>這是公告標題的第6行</li>
<li>這是公告標題的第7行</li>
<li>這是公告標題的第8行</li>
</ul>
</div>
</body>
</html>
顯示效果: