基于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 相关文章推荐
3Z版基于jquery的图片复选框(asp.net+jquery)
Apr 12 Javascript
用javascript替换URL中的参数值示例代码
Jan 27 Javascript
javascript 中__proto__和prototype详解
Nov 25 Javascript
JavaScript动态创建link标签到head里的方法
Dec 22 Javascript
jQuery拖拽插件gridster使用指南
Apr 21 Javascript
使用postMesssage()实现iframe跨域页面间的信息传递
Mar 29 Javascript
js实现非常棒的弹出div
Oct 06 Javascript
JS实现加载和读取XML文件的方法详解
Apr 24 Javascript
jQuery实现用户信息表格的添加和删除功能
Sep 12 jQuery
详解Vue数据驱动原理
Nov 17 Javascript
JavaScript 实现继承的几种方式
Feb 19 Javascript
JS实现页面炫酷的时钟特效示例
Aug 14 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实现从ftp服务器上下载文件树到本地电脑的程序
2009/02/10 PHP
PHP文件大小格式化函数合集
2014/03/10 PHP
codeigniter自带数据库类使用方法说明
2014/03/25 PHP
ThinkPHP之N方法实例详解
2014/06/20 PHP
PHP中常见的缓存技术实例分析
2015/09/23 PHP
smarty简单应用实例
2015/11/03 PHP
使用ltrace工具跟踪PHP库函数调用的方法
2016/04/25 PHP
PHP实现防盗链的方法分析
2017/07/25 PHP
PHP获取访问设备信息的方法示例
2019/02/20 PHP
prototype 中文参数乱码解决方案
2009/11/09 Javascript
Javascript生成全局唯一标识符(GUID,UUID)的方法
2016/02/27 Javascript
基于JS实现数字+字母+中文的混合排序方法
2016/06/06 Javascript
Extjs表单输入框异步校验的插件实现方法
2017/03/20 Javascript
微信小程序 request接口的封装实例代码
2017/04/26 Javascript
前端图片懒加载(lazyload)的实现方法(提高用户体验)
2017/08/21 Javascript
AngularJS 控制器 controller的详解
2017/10/17 Javascript
React.Js添加与删除onScroll事件的方法详解
2017/11/03 Javascript
详解Vue项目中出现Loading chunk {n} failed问题的解决方法
2018/09/14 Javascript
javascript中如何判断类型汇总
2019/05/14 Javascript
layui table复选框禁止某几条勾选的实例
2019/09/20 Javascript
深入解析Python中的urllib2模块
2015/11/13 Python
python 根据正则表达式提取指定的内容实例详解
2016/12/04 Python
Python上下文管理器用法及实例解析
2019/11/11 Python
解决Jupyter NoteBook输出的图表太小看不清问题
2020/04/16 Python
Spring http服务远程调用实现过程解析
2020/06/11 Python
浅析python连接数据库的重要事项
2021/02/22 Python
canvas生成带二维码海报的踩坑记录
2019/09/11 HTML / CSS
LUISAVIAROMA德国官网:时尚奢侈品牌购物网站
2020/11/12 全球购物
写出二分查找算法的两种实现
2013/05/13 面试题
生物技术专业研究生自荐信
2013/09/22 职场文书
卫校护理专业毕业生求职信
2013/11/26 职场文书
法人委托书
2014/07/31 职场文书
搞笑的爱情检讨书
2014/10/01 职场文书
利用前端HTML+CSS+JS开发简单的TODOLIST功能(记事本)
2021/04/13 Javascript
详解java如何集成swagger组件
2021/06/21 Java/Android
AJAX实现省市县三级联动效果
2021/10/16 Javascript