jquery插件之文字间歇自动向上滚动

该插件乃本博客作者所写,目的在于提升作者的js能力,也给一些js菜鸟在使用插件时提供一些便利,老鸟就悠然地飞过吧。

此插件旨在实现目前较为流行的文字间歇向上滚动特效,当鼠标移动到文字上时,向上滚动会停止,当鼠标离开时,向上滚动继续。整体代码如下:

<!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>文字间歇向上滚动</title>
<style>
*{margin:0;padding:0;font-size:12px;}
li{list-style:none;}
.box{margin:20px;width:320px;height:195px;border:1px solid #ddd;padding:5px 5px 10px;overflow:hidden;}
.box ul li{line-height:25px;}
</style>
<script type="text/javascript" src="../../jquery-1.7.1.js"></script>
</head> <body>
<div class="box">
<ul>
<li>01这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>02这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>03这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>04这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>05这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>06这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>07这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>08这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
<li>09这是一个无缝向上滚动的特效,是我第一次写这样的插件</li>
</ul>
</div>
<script>
/*
* textSlider 0.1
* Copyright (c) 2014 tnnyang http://tnnyang.cnblogs.com/
* Dependence jquery-1.7.1.js
*/
;(function($){
$.fn.textSlider = function(options){
var defaults = { //初始化参数
scrollHeight:25,
line:1,
speed:'normal',
timer:2000
};
var opts = $.extend(defaults,options); this.each(function(){
var timerID;
var obj = $(this);
var $ul = obj.children("ul");
var $height = $ul.find("li").height();
var $Upheight = 0-opts.line*$height;
obj.hover(function(){
clearInterval(timerID);
},function(){
timerID = setInterval(moveUp,opts.timer);
}); function moveUp(){
$ul.animate({"margin-top":$Upheight},opts.speed,function(){
for(i=0;i<opts.line;i++){ //只有for循环了才可以设置一次滚动的行数
$ul.find("li:first").appendTo($ul);
}
$ul.css("margin-top",0);
});
}; timerID = setInterval(moveUp,opts.timer);
});
};
})(jQuery)
</script>
<script>
$(function(){
$(".box").textSlider({
line:2
});
})
</script>
</body>
</html>
上一篇:jquery 文字向上滚动+CSS伪类before和after的应用


下一篇:vue中使用对非表单元素使用contenteditable的问题