欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jquery简单实现纵向的无缝滚动代码实例

程序员文章站 2022-06-04 12:00:05
简单实现纵向无缝滚动(不要忘记引入jquery文件哦) 看效果: 1、html代码

简单实现纵向无缝滚动(不要忘记引入jquery文件哦)

看效果:

jquery简单实现纵向的无缝滚动代码实例

1、html代码

<!doctype html>
<html lang="zh-cn">
<head>
<meta charset="utf-8">
<title>简单的jquery无缝向上滚动效果</title>
</head>
<body>
	<div class="myscroll">
		<ul>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
			<li><a href="">简单的jquery无缝向上滚动效果</a></li>
		</ul>
	</div>
</body>
</html>

2、css代码

<style>
* { margin: 0; padding: 0;list-style:none;}
.myscroll {
	width: 300px;
	height: 260px;
	margin: 0 auto;
	line-height: 26px;
	font-size: 12px;
	overflow: hidden;
	border:2px solid orange;
}
.myscroll li {
	height: 26px;
	padding:0 10px;
	font-size:14px;
}
.myscroll a {
	color: #333;
	text-decoration: none;
}
.myscroll a:hover {
	color: orange;
	text-decoration: underline;
}
</style>

3、js代码

(function($){
	$.fn.myscroll = function(options){
	//默认配置
	var defaults = {
		speed:40, //滚动速度,值越大速度越慢
		rowheight:24 //每行的高度
	};

	var opts = $.extend({}, defaults, options),
		intid = [];

	function marquee(obj, step){

		obj.find("ul").animate({//html中必须有的ul
			margintop: '-=1'
		},0,function(){
				var s = math.abs(parseint($(this).css("margin-top")));
				if(s >= step){
					$(this).find("li").slice(0, 1).appendto($(this));//截取ul中的第一个li,添加到ul的最后
					$(this).css("margin-top", 0);
				}
			});
		}

		this.each(function(i){
			var rowheight = opts["rowheight"],
				speed = opts["speed"],
				_this = $(this);//这里的_this指向div.myscroll

			intid[i] = setinterval(function(){
				if(_this.find("ul").height()<=_this.height()){//当ul的高度小于html中,div.myscroll的高度,则结束定时器
					clearinterval(intid[i]);
				}else{
					marquee(_this, rowheight);
				}
			}, speed);

			_this.hover(function(){//鼠标移动到div.myscroll上时,结束定时器
				clearinterval(intid[i]);
			},function(){//鼠标离开div.myscroll容器,判断ul的高度若小于等于div.myscroll高度,则结束定时器(不滚动),否则调用marquee函数
				intid[i] = setinterval(function(){
					if(_this.find("ul").height()<=_this.height()){
						clearinterval(intid[i]);
					}else{
						marquee(_this, rowheight);
					}
				}, speed);
			});
		});
	}
})(jquery);

4、调用

$(function(){
	$('.myscroll').myscroll({
		speed: 40, //数值越大,速度越慢
		rowheight: 26 //li的高度
	});
});

以上所述是小编给大家介绍的jquery简单实现纵向的无缝滚动详解整合,希望对大家有所帮助