• 欢迎访问开心洋葱网站,在线教程,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站,欢迎加入开心洋葱 QQ群
  • 为方便开心洋葱网用户,开心洋葱官网已经开启复制功能!
  • 欢迎访问开心洋葱网站,手机也能访问哦~欢迎加入开心洋葱多维思维学习平台 QQ群
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏开心洋葱吧~~~~~~~~~~~~~!
  • 由于近期流量激增,小站的ECS没能经的起亲们的访问,本站依然没有盈利,如果各位看如果觉着文字不错,还请看官给小站打个赏~~~~~~~~~~~~~!

jQuery向上循环滚动,文字渐显效果(仿新浪微博微博效果)

JavaScript 开心洋葱 2472次浏览 0个评论

jQuery向上循环滚动,文字渐显效果(仿新浪微博微博效果)

 

测试代码:

<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>

<script type="text/javascript" src="http://jbqy.l/statics/js/mejs/jQuery-1.7.2.min.js"></script>
<div class="messagewrap">
<ul>
<li>
<li>,请自行复制或者设置重复区域–></li>
<li>,请自行复制或者设置重复区域–></li>
<li>,请自行复制或者设置重复区域–></li>
<li>,请自行复制或者设置重复区域–></li>
<li>,请自行复制或者设置重复区域–></li>
</ul>
<div class="bottomcover">
<!–为了符合w3c要求不能有空标签的要求,此处可选择写一个&nbsp;–>
</div>
</div>


<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>

代码简要说明:

1 、内容持续滚动;

2、 新微博将下面的微博先推下去,然后淡入进来;

3、 鼠标经过内容暂停滚动;

4、 容器底部渐变消失在背景色下。

上述4个需求之中,需求1-3为js技术实现,需求4为css技术实现,下面逐个需求来讲。

#p#副标题#e#

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

加入示例的两个滚动实现代码:

<style>
.messagewrap {
	overflow:hidden;
	position:relative;
	width:230px;
	height:170px
}
.bottomcover {
	width:230px;
	height:45px;
	position:absolute;
	bottom:0;
	left:0;
	pointer-events:none;
	background:url(halftransp.png) left bottom no-repeat;
	/*某从背景色向上渐变透明图片*/ _display:none;/*针对IE6体验降级*/
}
</style>
<div class="messagewrap">
  <ul id="up_yt">
    <li><a href="http://www.awzsr.com">高中部德育新闻周刊——第一期</a></li>
    <li><a href="http://www.awzsr.com">The IUP Newsle..</a></li>
    <li><a href="http://www.awzsr.com">News from inte..</a></li>
    <li><a href="http://www.awzsr.com">IUP newsletter..</a></li>
    <li><a href="http://www.awzsr.com">怀着一颗感恩的心 创造自己的..</a></li>
    <li><a href="http://www.awzsr.com">IUP newsletter..</a></li>
    <li><a href="http://www.awzsr.com">美国高中新闻周刊——第二期 </a></li>
  </ul>
  <div class="bottomcover"> </div>
</div>
<div class="messagewrap">
  <ul id="up_yt1">
    <li><a href="http://www.awzsr.com">雅思通过率100%</a></li>
    <li><a href="http://www.awzsr.com">签证通过率100%</a></li>
    <li><a href="http://www.awzsr.com">光荣榜</a></li>
    <li><a href="http://www.awzsr.com">社会媒体高度肯定</a></li>
  </ul>
</div>
<script> 
$(function(){
msgmove(); 
$("#up_yt").hover(function(){
$(this).attr("name","hovered"); //鼠标经过设置ul的name值为"hovered"
},function(){
$(this).removeAttr("name");
});
});
 
$(function(){
msgmove1(); 
$("#up_yt1").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($("#up_yt").attr("name") != "hovered"){
//判断ul的name属性是否为"hovered",决定下面代码块是否运行,以实现鼠标经过暂停滚动。
var height = $("#up_yt li:last").height();
if(isIE6){
//判断IE6,jQuery的animate动画和opacity透明在一起使用在IE6中会出现中文重影现象,
//所以在ie6中实行透明的禁用。
$("#up_yt li:last").css({"height":0});
}else{ $("#up_yt li:last").css({"opacity":0,"height":0});
//列表最后的li透明和高度设置为0 }
$("#up_yt li:first").before($("#up_yt li:last"));
//把列表最后的li提升到顶部,实现有限列表项无限循环滚动显示
$("#up_yt li:first").animate({"height":height},300);
//列表顶部的li高度逐渐变高以把下面的li推下去 if(!isIE6){
$("#up_yt li:first").animate({"opacity":"1"},300);
//在非IE6浏览器中设置透明淡入效果
}
}
setTimeout("msgmove()",5000);
//设置5秒滚动一次
}
 
 
function msgmove1(){ var isIE=!!window.ActiveXObject;
var isIE6=isIE&&!window.XMLHttpRequest;
if($("#up_yt1").attr("name") != "hovered"){
//判断ul的name属性是否为"hovered",决定下面代码块是否运行,以实现鼠标经过暂停滚动。
var height = $("#up_yt1 li:last").height();
if(isIE6){
//判断IE6,jQuery的animate动画和opacity透明在一起使用在IE6中会出现中文重影现象,
//所以在ie6中实行透明的禁用。
$("#up_yt1 li:last").css({"height":0});
}else{ $("#up_yt1 li:last").css({"opacity":0,"height":0});
//列表最后的li透明和高度设置为0 }
$("#up_yt1 li:first").before($("#up_yt1 li:last"));
//把列表最后的li提升到顶部,实现有限列表项无限循环滚动显示
$("#up_yt1 li:first").animate({"height":height},300);
//列表顶部的li高度逐渐变高以把下面的li推下去 if(!isIE6){
$("#up_yt1 li:first").animate({"opacity":"1"},300);
//在非IE6浏览器中设置透明淡入效果
}
}
setTimeout("msgmove1()",5000);
//设置5秒滚动一次
}
</script>

 


开心洋葱 , 版权所有丨如未注明 , 均为原创丨未经授权请勿修改 , 转载请注明jQuery向上循环滚动,文字渐显效果(仿新浪微博微博效果)
喜欢 (0)

您必须 登录 才能发表评论!

加载中……