微博客

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

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之后,鼠标就可以透过绝对定位在文字上的图片选中下面的文字。

网站又更新了一个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" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
    <title></title>
    <style type="text/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体验降级*/} 
    </style>
    <script type="text/javascript"> 
    $(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>
</head>
<body>

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

 
 
    
</body>
</html>
posted on 2012-11-08 09:46  飞鸟42  阅读(502)  评论(0编辑  收藏  举报