jQuery滚动新闻实现代码


Posted in Javascript onJune 26, 2016

     网上下载了一个Jquery新闻滚动Demo,效果不错。我根据自己情况,做了些调整。
    下载后,除了Html及Jquery.js,还有三个文件,分别是Css,主Js和一个定位Js(jquery.dimensions.js),Css文件完全可以通过动态赋值实现,省的在Css文件中添加了,况且可以重定义,应该效果更好。
    定位Js只用到一个方法,我把它整合到之中了,少加载一个是一个么。
    原Demo是一行显示的滚动效果,有一个Bug,即不等的多行显示时会跑错,已修复。
    原Demo有一个mouseover属性,我一般不用(效果不好,看一下实现方法也有漏洞,在多行时效果更差),删除了。

    借鉴别人的思路与代码,不敢独享。

删除的部分:

$('> ul', this)
    .bind('mouseover', function(e) {
     if ($(e.target).is('li')) {
      $(e.target).addClass('hover');
     }
    })
    .bind('mouseout', function(e) {
     if ($(e.target).is('li')) {
      $(e.target).removeClass('hover');
     }
    });

调整后代码:

html部分:

<div id="tbNews">
<ul>
 <li>1、滚动新闻,滚动新闻,滚动新闻,滚动新闻,滚动新闻</li>
 <li>2、滚动新闻,滚动新闻</li>
 <li>3、滚动新闻,滚动新闻,滚动新闻,滚动新闻</li>
 <li>4、滚动新闻,滚动新闻,滚动新闻,滚动新闻,滚动新闻</li>
 <li>5、滚动新闻</li>
</ul>
</div>
<script language="JavaScript" src="jdNewsScroll.js" type="text/javascript">
</script>
<script defer="defer" language="JavaScript" type="text/javascript">
$(function() {
 $('#tbNews').jdNewsScroll({divWidth:130,divHeight:50,fontSize:'10.5pt'});
});
</script>

Js代码:

(function($){
  var ELMS = [];
  $.fn.jdNewsScroll = function(settings) {
  settings = $.extend({}, arguments.callee.defaults, settings);
 $(this).css({"position":"relative","overflow":"hidden","width":settings.divWidth,"height":settings.divHeight});
 $(this).find("ul").css({"position":"relative","list-style-type":"none","font-size":settings.fontSize,"margin":"0px"});
 $(this).find("li").css({"line-height":"130%","margin":"0px","padding":"2px 10px 1px 10px"});
  $(this).each(function(){
   this.$settings = settings;
   this.$pause = false;
   this.$counter = settings.beginTime;
   $(this).hover(function(){ $(this).jdNewsScrollPause(true) }, function(){ $(this).jdNewsScrollPause(false) });
   ELMS.push(this);
  });
  return this;
 };
 $.fn.jdNewsScroll.defaults = {
  beginTime: 10,
  fontSize: '9pt',
  divWidth: '100%',
  divHeight: '200px',
  lineHeight: '130%',
  delay:  20,
  step: 2
 };
 $.fn.jdNewsScrollPause = function(pause) {
  return this.each(function() {
   this.$pause = pause;
  });
 }
 function outerHeight(options) {
  if (!this[0]) 0;
  options = $.extend({ margin: false }, options || {});
  return this[0] == window || this[0] == document ?
   this.height() : this.is(':visible') ?
    this[0].offsetHeight + (options.margin ? (num(this, 'marginTop') + num(this, 'marginBottom')) : 0) :
    this.height() 
     + num(this,'borderTopWidth') + num(this, 'borderBottomWidth') 
     + num(this, 'paddingTop') + num(this, 'paddingBottom')
     + (options.margin ? (num(this, 'marginTop') + num(this, 'marginBottom')) : 0);
 }

 setInterval(scroll, 80);
 function scroll() {
  for (var i = 0; i < ELMS.length; i++) {
   var elm = ELMS[i];
   if (elm && !elm.$pause) {
    if (elm.$counter == 0) {
     var ul  = $('> ul', elm)[0];
     if (!elm.$steps) {
      elm.$steps = $('> li:first-child', ul).outerHeight();
      elm.$step = 0;
     }
     if ((elm.$steps + elm.$step) <= 0) {
      elm.$counter  = elm.$settings.delay;
      elm.$steps   = false;
      $(ul).css('top', '0').find('> li:last-child').after($('> li:first-child', ul));
      $('> *', ul).not('li').remove();
     } else {
      elm.$step -= elm.$settings.step;
      if (-elm.$step > elm.$steps) {
       elm.$step = -elm.$steps;
      }
      ul.style.top = elm.$step + 'px';
     }
    } else {
     elm.$counter--;
    }
   }
  }
 };
})(jQuery);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery AJAX 调用WebService实现代码
Mar 24 Javascript
javascript开发随笔一 preventDefault的必要
Nov 25 Javascript
javascript实现点击按钮让DIV层弹性移动的方法
Feb 24 Javascript
基于Css3和JQuery实现打字机效果
Aug 11 Javascript
利用babel将es6语法转es5的简单示例
Dec 01 Javascript
使用vue-cli+webpack搭建vue开发环境的方法
Dec 22 Javascript
vue.js中实现登录控制的方法示例
Apr 23 Javascript
jQuery.validate.js表单验证插件的使用代码详解
Oct 22 jQuery
通过cordova将vue项目打包为webapp的方法
Feb 02 Javascript
Vue中computed、methods与watch的区别总结
Apr 10 Javascript
jquery ui 实现 tab标签功能示例【测试可用】
Jul 25 jQuery
微信小程序开发(三):返回上一级页面并刷新操作示例【页面栈】
Jun 01 Javascript
js css实现垂直方向自适应的三角提示菜单
Jun 26 #Javascript
JS中的进制转换以及作用
Jun 26 #Javascript
JavaScript类型系统之布尔Boolean类型详解
Jun 26 #Javascript
基于JavaScript实现单选框下拉菜单添加文件效果
Jun 26 #Javascript
JQuery控制图片由中心点逐渐放大效果
Jun 26 #Javascript
JavaScript直播评论发弹幕切图功能点集合效果代码
Jun 26 #Javascript
jquery实现上传文件大小类型的验证例子(推荐)
Jun 25 #Javascript
You might like
php 格式化数字的时候注意数字的范围
2010/04/13 PHP
smarty模板中使用get、post、request、cookies、session变量的方法
2014/04/24 PHP
PHP实现微信发红包程序
2015/08/24 PHP
PHP中使用substr()截取字符串出现中文乱码问题该怎么办
2015/10/21 PHP
laravel中Redis队列监听中断的分析
2020/09/14 PHP
javascript 自定义事件初探
2009/08/21 Javascript
jQuery登陆判断简单实现代码
2013/04/21 Javascript
jQuery焦点图切换特效插件封装实例
2013/08/18 Javascript
jQuery学习笔记之jQuery构建函数的7种方法
2014/06/03 Javascript
javascript实现简单的页面右下角提示信息框
2015/07/31 Javascript
PHP捕捉异常中断的方法
2016/10/24 Javascript
正则表达式替换html元素属性的方法
2016/11/26 Javascript
Node连接mysql数据库方法介绍
2017/02/07 Javascript
ie下js不执行的几种可能
2017/02/28 Javascript
纯jQuery实现前端分页功能
2017/03/23 jQuery
Vue filter介绍及其使用详解
2017/10/21 Javascript
vue、react等单页面项目应该这样子部署到服务器
2018/01/03 Javascript
js实现动态改变radio状态的方法
2018/02/28 Javascript
js回文数的4种判断方法示例
2019/06/04 Javascript
python中的lambda表达式用法详解
2016/06/22 Python
使用Python编写Prometheus监控的方法
2018/10/15 Python
python进阶之多线程对同一个全局变量的处理方法
2018/11/09 Python
python批量读取文件名并写入txt文件中
2020/09/05 Python
Python编写带选项的命令行程序方法
2019/08/13 Python
python小项目之五子棋游戏
2019/12/26 Python
pyautogui自动化控制鼠标和键盘操作的步骤
2020/04/01 Python
英国布鲁姆精品店:Bloom Boutique
2018/03/01 全球购物
合同协议书格式
2014/04/18 职场文书
新闻专业毕业生求职信
2014/08/08 职场文书
十佳好少年事迹材料
2014/08/21 职场文书
思想纪律作风整顿剖析材料
2014/10/11 职场文书
专题组织生活会发言材料
2014/10/17 职场文书
革命电影观后感
2015/06/18 职场文书
如何用python插入独创性声明
2021/03/31 Python
Feign调用传输文件异常的解决
2021/06/24 Java/Android
canvas实现贪食蛇的实践
2022/02/15 Javascript