基于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 相关文章推荐
往光标所在位置插入值的js代码
Sep 22 Javascript
Jquery.Form 异步提交表单的简单实例
Mar 03 Javascript
jQuery.parseJSON(json)将JSON字符串转换成js对象
Jul 27 Javascript
jquery限定文本框只能输入数字(整数和小数)
Jan 08 Javascript
基于JavaScript实现 网页切出 网站title变化代码
Apr 03 Javascript
js不间断滚动的简单实现
Jun 03 Javascript
JS正则匹配中文的方法示例
Jan 06 Javascript
微信小程序 简单教程实例详解
Jan 13 Javascript
纯JavaScript实现实时反馈系统时间
Oct 26 Javascript
angular1配合gulp和bower的使用教程
Jan 19 Javascript
CKeditor富文本编辑器使用技巧之添加自定义插件的方法
Jun 14 Javascript
微信小程序后端(java)开发流程的详细步骤
Nov 13 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中ob函数缓冲机制深入理解
2015/08/03 PHP
php session实现多级目录存放实现代码
2016/02/03 PHP
Prototype使用指南之hash.js
2007/01/10 Javascript
jquery 查找iframe父级页面元素的实现代码
2011/08/28 Javascript
Ajax同步与异步传输的示例代码
2013/11/21 Javascript
jquery.cookie() 方法的使用(读取、写入、删除)
2013/12/05 Javascript
深入理解JavaScript高级之词法作用域和作用域链
2013/12/10 Javascript
node.js Web应用框架Express入门指南
2014/05/28 Javascript
js实现点击图片改变页面背景图的方法
2015/02/28 Javascript
JS设置网页图片vspace和hspace属性的方法
2015/04/01 Javascript
利用Angular.js编写公共提示模块的方法教程
2017/05/28 Javascript
详解Vue中使用插槽(slot)、聚类插槽
2019/04/12 Javascript
JavaScript获取页面元素的常用方法详解
2019/09/28 Javascript
vue-autoui自匹配webapi的UI控件的实现
2020/03/20 Javascript
浅谈element中InfiniteScroll按需引入的一点注意事项
2020/06/05 Javascript
学习python (1)
2006/10/31 Python
Python正则表达式知识汇总
2017/09/22 Python
Tensorflow之构建自己的图片数据集TFrecords的方法
2018/02/07 Python
python3+PyQt5使用数据库窗口视图
2018/04/24 Python
Python3.5集合及其常见运算实例详解
2019/05/01 Python
python把ipynb文件转换成pdf文件过程详解
2019/07/09 Python
Python 线程池用法简单示例
2019/10/02 Python
通过字符串导入 Python 模块的方法详解
2019/10/27 Python
美国成衣女装品牌:CHICO’S
2016/09/19 全球购物
彼得罗夫美国官网:Peter Thomas Roth美国(青瓜面膜)
2017/11/05 全球购物
字符串str除首尾字符外的其他字符按升序排列
2013/03/08 面试题
出生公证书样本
2014/04/04 职场文书
写求职信要注意什么问题
2014/04/12 职场文书
2015届大学生就业推荐表自我评价
2014/09/27 职场文书
王金山在党的群众路线教育实践活动总结大会上的讲话稿
2014/10/25 职场文书
大学生在校表现评语
2014/12/31 职场文书
个人工作违纪检讨书
2015/05/05 职场文书
2016新年问候语大全
2015/11/11 职场文书
MySQL索引篇之千万级数据实战测试
2021/04/05 MySQL
利用Apache Common将java对象池化的问题
2022/06/16 Servers
JS实现刷新网页后之前浏览位置保持不变示例详解
2022/08/14 Javascript