jQuery上下滚动效果,jquery无缝滚动,仿新浪微博大厅滚动
新浪微博未登录首页有一个“大家正在说”的模块,动态滚动最新发布的微博。从需求上来说,这个功能需要实时调用最新的微博数据,单就前端开发来说,其需求可以拆分如下:1 内容持续滚动;2 新微博将下面的微博先推下去,然后淡入进来;3 鼠标经过内容暂停滚动;4 容器底部渐变消失在背景色下。上述4个需求之中,需求1-3为js技术实现,需求4为css技术实现,下面逐个需求来讲。需求1和需
·
新浪微博未登录首页有一个“大家正在说”的模块,动态滚动最新发布的微博。从需求上来说,这个功能需要实时调用最新的微博数据,单就前端开发来说,其需求可以拆分如下:
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实现仿新浪微博大厅和腾讯微博首页滚动效果
综合代码如下:HTML
<body> <div class="messagewrap"> <ul> <li>中国1,你好啊</li> <li>中国2,你好啊</li> <li>中国3,你好啊</li> <li>中国4,你好啊</li> </ul> <div class="bottomcover"> <!–为了符合w3c要求不能有空标签的要求,此处可选择写一个 –> </div> </div></body>
<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>
.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>
$(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秒滚动一次
}
随便介绍另一个无缝滚动:基于jQuery的上下无缝滚动应用(单行或多行)
核心jQuery代码:
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秒滚动一次
}
随便介绍另一个无缝滚动:基于jQuery的上下无缝滚动应用(单行或多行)
核心jQuery代码:
$(function () {
var _wrap = $('ul.line'); //定义滚动区域
var _interval = 2000; //定义滚动间隙时间
var _moving; //需要清除的动画
_wrap.hover(function () {
clearInterval(_moving); //当鼠标在滚动区域中时,停止滚动
}, function () {
_moving = setInterval(function () {
var _field = _wrap.find('li:first'); //此变量不可放置于函数起始处,li:first取值是变化的
var _ = _field.height(); //取得每次滚动高度(多行滚动情况下,此变量不可置于开始处,否则会有间隔时长延时)
_field.animate({ marginTop: -_h + 'px' }, 600, function () {//通过取负margin值,隐藏第一行
_field.css('marginTop', 0).appendTo(_wrap); //隐藏后,将该行的margin值置零,并插入到最后,实现无缝滚动
})
}, _interval)//滚动间隔时间取决于_interval
}).trigger('mouseleave'); //函数载入时,模拟执行mouseleave,即自动滚动
});
</script>
var _wrap = $('ul.line'); //定义滚动区域
var _interval = 2000; //定义滚动间隙时间
var _moving; //需要清除的动画
_wrap.hover(function () {
clearInterval(_moving); //当鼠标在滚动区域中时,停止滚动
}, function () {
_moving = setInterval(function () {
var _field = _wrap.find('li:first'); //此变量不可放置于函数起始处,li:first取值是变化的
var _ = _field.height(); //取得每次滚动高度(多行滚动情况下,此变量不可置于开始处,否则会有间隔时长延时)
_field.animate({ marginTop: -_h + 'px' }, 600, function () {//通过取负margin值,隐藏第一行
_field.css('marginTop', 0).appendTo(_wrap); //隐藏后,将该行的margin值置零,并插入到最后,实现无缝滚动
})
}, _interval)//滚动间隔时间取决于_interval
}).trigger('mouseleave'); //函数载入时,模拟执行mouseleave,即自动滚动
});
</script>
更多推荐
已为社区贡献2条内容
所有评论(0)