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>
时间: 2024-08-07 01:51:39

jquery插件之文字间歇自动向上滚动的相关文章

vue文字间歇无缝向上滚动

公司的管理系统中有"文字间歇无缝向上滚动"的需求,现在这种需求基本在项目开发中已经消失了,没什么新颖的,但架不住公司高层喜欢这种玩意儿,所以,作为开发人员,即使你有一百个不乐意,谁让是人家给你发工资呢!!! 其实,这种用在vue项目中的需求跟原生js的实现方法基本一致,且实现的方法有多种,今天就单拎出来一种实现方法吧: <div class="scroll-up" ref="scroll"> <ul> <li v-f

高仿京东APP首页“京东快报”自动向上滚动的广告条

转载请标明出处: http://blog.csdn.net/hai_qing_xu_kong/article/details/51013562 本文出自:[顾林海的博客] 前言 上次在京东APP上买东西时,发现首页中间有块叫"京东快报"的栏目,其中广告条能自动向上滚动,效果还不错,看到这个效果,第一个念头就是我能不能实现,于是就诞生了这篇文章. 我们看看实现后的效果: 实现原理 起初看到这个效果时,第一个想法就是向上移动动画+定时器,但当我准备写时发现,滚动时上下文字都是逐渐出来的(有

实现窗口中的文档自动向上滚动,方便阅读

<!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" xml:lang="en"> <head> <meta ht

文字列表无缝向上滚动JavaScript代码

<!DOCTYPE html> <html> <head> <meta charset=utf-8> <title>文字列表无缝向上滚动JavaScript代码-代码库</title> <style> *{margin:0px;padding:0px;border:0px;} body{font-size:12px} a{color:#333333; text-decoration:none;} a:hover{color

jquery插件之文字无缝向上滚动

该插件乃本博客作者所写,目的在于提升作者的js能力,也给一些js菜鸟在使用插件时提供一些便利,老鸟就悠然地飞过吧. 此插件旨在实现目前较为流行的无缝向上滚动特效,当鼠标移动到文字上时,向上滚动会停止,当鼠标离开时,向上滚动继续.整体代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional

jQuery插件--图片文字向上向左循环滚动

需要引用jquery 调用非常简单: 一. 向上滚动 $(".scroll_two").jScroll({vertical: true}); <div class="box scroll_two"> <ul> <li><a href="#">声明</a>| <a href="#">农夫山泉关于公益捐赠的严正声明</a></li> &

基于zepto的插件之移动端无缝向上滚动并上下触摸滑动

该插件乃本博客作者所写,目的在于提升作者的js能力,也给一些js菜鸟在使用插件时提供一些便利,老鸟就悠然地飞过吧. 公司的移动端项目是基于zepto的,有一个页面要求文字能够无缝地不停向上滚动,但查了网上的资料,大多都是基于jquery的,虽然稍作修改就可以用于移动端,但不能实现触摸上下翻滚.所以就去了zepto的官网查看其API,却发现如果要使用zepto的swipe()方法,需要引用其已经封装好的touch.js文件,我就赶紧引用了这个js文件,可在实际测试中,官网给出的touch.js文件

单行自动向上滚动的新闻列表

<!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> <style> body, div, dl, dt, dd, ul, ol, li, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote { margin: 0;

列表内容自动向上滚动(原生JS)

效果展示 (鼠标移入,滚动停止:鼠标移出,滚动继续) 实现原理 1. html结构:核心是ul > li,ul外层包裹着div.因为想要内容循环滚动无缝衔接,所以在原有ul后面还要有一个一样内容的ul.如下图:    (红色边框为可视区域div,此处为了方便查看效果去除overflow:hidden:) 2. 样式方面:由于要滚动,所以必须2个ul的高度 > 外层可视div高度,且div必须设置overflow:hidden; 代码实现 HTML: 1 <div id="rev