zoukankan      html  css  js  c++  java
  • 【小模块】内容循环滚动(仿新浪微博未登录首页滚动微博显示)

    本文内容应用在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>
  • 相关阅读:
    vscode中执行gulp task的简便方法
    5G即将到来,你还会购买4G手机吗?
    小屏幕手机汇总
    NoSQL数据库的分布式算法详解
    如何在网页界面设计中正确的留出空白空间?
    iconfont的三种使用方式
    MySQL修改密码方法汇总
    Docker镜像与容器
    微观经济学
    经营的原点 书评
  • 原文地址:https://www.cnblogs.com/bienfantaisie/p/1995733.html
Copyright © 2011-2022 走看看