基于jquery的内容循环滚动小模块(仿新浪微博未登录首页滚动微博显示)


Posted in Javascript onMarch 28, 2011

从需求上来说,这个功能需要实时调用最新的微博数据,单就前端开发来说,其需求可以拆分如下:
1 内容持续滚动;
2 新微博将下面的微博先推下去,然后淡入进来;
3 鼠标经过内容暂停滚动;
4 容器底部渐变消失在背景色下。
上述4个需求之中,需求1-3为js技术实现,需求4为css技术实现,下面逐个需求来讲。
需求1和需求2:内容持续滚动的需求有些类似前一篇文章《小模块:公告滚动并暂停》中介绍的功能,在那篇文章中,此功能使用css的position定位来控制整个ul列表的移动动画。结合需求2,我们可以写得更简单一些,让最后的li元素定时插入第一个li元素的上方,然后采用animate方法来改变li的高度和透明效果。而不停顿的滚动依然要用到setTimeout方法。在没有新数据加载的情况下,要实现有限内容循环滚动。
需求3:鼠标经过暂停的需求可以当鼠标hover经过的时候在某元素上加上某属性的值,这里采用name属性——判断此值是否存在,如果存在则不执行代码。
需求4:可以通过在内容上覆盖渐变的png24图片来实现,IE6对png24支持不好,如果需要顾及性能的话,在此容器上加display:none的IE6hack。接下来的问题是解决图片覆盖到文字之上,文字如何可以点击或选中的问题,这时候需要一个特殊的css属性“pointer-events”,此属性的值设为none之后,鼠标就可以透过绝对定位在文字上的图片选中下面的文字。
综合代码如下:
HTML

<div class="messagewrap"> 
<ul> 
<li><!--多个li,请自行复制或者设置重复区域--></li> 
</ul> 
<div class="bottomcover"> 
<!--为了符合w3c要求不能有空标签的要求,此处可选择写一个 --> 
</div> 
</div>

CSS
.messagewrap{overflow:hidden;position:relative;width:500px;height:300px} 
li{height:50px;} 
.bottomcover{width:500px;height:45px;position:absolute;bottom:0;left:0; 
pointer-events:none;background:url(halftransp.png) left bottom no-repeat; 
/*某从背景色向上渐变透明图片*/ _display:none;/*针对IE6体验降级*/}

JS
<script> 
$(function(){ 
msgmove(); 
$("ul").hover(function(){ 
$(this).attr("name","hovered"); //鼠标经过设置ul的name值为"hovered" 
},function(){ 
$(this).removeAttr("name"); 
}); 
}); 
function msgmove(){ 
var isIE=!!window.ActiveXObject; 
var isIE6=isIE&&!window.XMLHttpRequest; 
if($("ul").attr("name") != "hovered"){ 
//判断ul的name属性是否为"hovered",决定下面代码块是否运行,以实现鼠标经过暂停滚动。 
var height = $("li:last").height(); 
if(isIE6){ 
//判断IE6,jQuery的animate动画和opacity透明在一起使用在IE6中会出现中文重影现象, 
//所以在ie6中实行透明的禁用。 
$("li:last").css({"height":0}); 
}else{ 
$("li:last").css({"opacity":0,"height":0}); 
//列表最后的li透明和高度设置为0 
} 
$("li:first").before($("li:last")); 
//把列表最后的li提升到顶部,实现有限列表项无限循环滚动显示 
$("li:first").animate({"height":height},300); 
//列表顶部的li高度逐渐变高以把下面的li推下去 
if(!isIE6){ 
$("li:first").animate({"opacity":"1"},300); 
//在非IE6浏览器中设置透明淡入效果 
} 
} 
setTimeout("msgmove()",5000); 
//设置5秒滚动一次 
} 
</script>
Javascript 相关文章推荐
javascript的tab切换原理与效果实现方法
Jan 10 Javascript
jQuery实现点击水纹波动动画
Apr 10 Javascript
jquery获取img的src值的简单实例
May 17 Javascript
sencha ext js 6 快速入门(必看)
Jun 01 Javascript
jstree单选功能的实现方法
Jun 07 Javascript
在vue里面设置全局变量或数据的方法
Mar 09 Javascript
JavaScript闭包相关知识解析
Oct 19 Javascript
node.js使用fs读取文件出错的解决方案
Oct 23 Javascript
JS实现骰子3D旋转效果
Oct 24 Javascript
基于javascript实现贪吃蛇经典小游戏
Apr 10 Javascript
vue2.0 watch里面的 deep和immediate用法说明
Oct 30 Javascript
避坑之 JavaScript 中的toFixed()和正则表达式
Apr 19 Javascript
jquery向.ashx文件post中文乱码问题的解决方法
Mar 28 #Javascript
JQuery.ajax传递中文参数的解决方法 推荐
Mar 28 #Javascript
jQuery中调用WebService方法小结
Mar 28 #Javascript
利用jQuery接受和处理xml数据的代码(.net)
Mar 28 #Javascript
jquery.combobox中文api和例子,修复了上面的小bug
Mar 28 #Javascript
基于jquery的下拉框改变动态添加和删除表格实现代码
Sep 12 #Javascript
基于jQuery的可用于选项卡及幻灯的切换插件
Mar 28 #Javascript
You might like
关于PHP自动判断字符集并转码的详解
2013/06/26 PHP
php 删除cookie方法详解
2014/12/01 PHP
Yii使用migrate命令执行sql语句的方法
2016/03/15 PHP
PHP获取用户访问IP地址的5种方法
2016/05/16 PHP
快速保存网页中所有图片的方法
2006/06/23 Javascript
一个很酷的拖动层的js类,兼容IE及Firefox
2009/06/23 Javascript
IE7中javascript操作CheckBox的checked=true不打勾的解决方法
2009/12/07 Javascript
复制js对象方法(详解)
2013/07/08 Javascript
把字符串按照特定的字母顺序进行排序的js代码
2014/01/28 Javascript
Jquery1.9.1源码分析系列(六)延时对象应用之jQuery.ready
2015/11/24 Javascript
javascript正则表达式中分组详解
2016/07/17 Javascript
bootstrapValidator表单验证插件学习
2016/12/30 Javascript
Node.Js中实现端口重用原理详解
2018/05/03 Javascript
javascript中如何判断类型汇总
2019/05/14 Javascript
基于vue-cli3和element实现登陆页面
2019/11/13 Javascript
[01:33]PWL开团时刻DAY2-开雾与反开雾
2020/10/31 DOTA
对pandas的dataframe绘图并保存的实现方法
2017/08/05 Python
使用Python检测文章抄袭及去重算法原理解析
2019/06/14 Python
基于Pyinstaller打包Python程序并压缩文件大小
2020/05/28 Python
PyQt5.6+pycharm配置以及pyinstaller生成exe(小白教程)
2020/06/02 Python
Python利用Faiss库实现ANN近邻搜索的方法详解
2020/08/03 Python
python爬取代理ip的示例
2020/12/18 Python
Python新建项目自动添加介绍和utf-8编码的方法
2020/12/26 Python
Python实现简单猜数字游戏
2021/02/03 Python
CSS3按钮鼠标悬浮实现光圈效果源码
2016/09/11 HTML / CSS
使用HTML5拍照示例代码
2013/08/06 HTML / CSS
日本民宿预约平台:STAY JAPAN
2017/07/01 全球购物
类和结构的区别
2012/08/15 面试题
swtich是否能作用在byte上,是否能作用在long上,是否能作用在String上?
2013/03/30 面试题
森林防火标语
2014/06/23 职场文书
班级心理活动总结
2014/07/04 职场文书
学习心理学的体会
2014/11/07 职场文书
世界红十字日活动总结
2015/02/10 职场文书
幼儿园大班开学寄语(2016秋季)
2015/12/03 职场文书
入党转正申请自我鉴定
2019/06/25 职场文书
创业计划书之校园跑腿公司
2019/09/24 职场文书