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

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

本文内容应用在http://www.tuixin11.com未登录首页

新浪微博未登录首页有一个“大家正在说”的模块,动态滚动最新发布的微博。从需求上来说,这个功能需要实时调用最新的微博数据,单就前端开发来说,其需求可以拆分如下:

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要求不能有空标签的要求,此处可选择写一个&nbsp; -->
</ 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>

你可能感兴趣的:(新浪微博)