web复习(三):js实现公告栏效果,间歇性滚动展示
2016-06-08 20:25
686 查看
使用js实现:公告栏间歇性展示效果
:思想,使用js操作,ul的scrollTop,并配合setTimeout和setInterval实现循环间歇滚动
代码:如下:<!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"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>无缝滚动</title> </head> <script src="jquery-1.12.4.js" type="text/javascript"></script> <style type="text/css"> *{margin:0; padding:0; border:0; } body{ margin:0 auto; } #container{ width:300px; position:relative; top:50px; } #title{ width:100%; height:50px; text-align:center; line-height:50px; font-size:1.3em; background-color:#0FF; } #scrollBox{ width:300px; height:144px; overflow:hidden; } #scrollBox ul{ height:144px; width:300px; } #scrollBox ul li{ height:24px; width:100%; text-align:left; font-size:24px; line-height:24px; } #scrollBox ul li a{ text-decoration:none; color:#f60; } #scrollBox ul li a:hover{ color:#000; font-size:smaller; } </style> <body> <div id="container"> <div id="title"><a href="#">更多</a></div> <div id="scrollBox"> <ul> <li><a href="#">1:C语言学习</a></li> <li><a href="#">2:html学习</a></li> <li><a href="#">3:css学习</a></li> <li><a href="#">4:javascript学习</a></li> <li><a href="#">5:jquery学习</a></li> <li><a href="#">6:htmll5和css3学习</a></li> </ul> </div> <div> <script type="text/javascript"> //window.onload=function(){ //获取滚动部分 var area=document.getElementById("scrollBox"); //设置全局定时器 var timer=null; //定义延迟 var delay=2000; //获取高度 var oLiHeight=$("#scrollBox li").height(); //速度 var speed=50; area.scrollTop=0; area.innerHTML+=area.innerHTML; function startScroll(){//开始运动 timer=setInterval("scrollUp()",speed); area.scrollTop++; } function scrollUp(){//循环运动 if(area.scrollTop%oLiHeight==0){ clearInterval(timer) setTimeout(startScroll,delay); }else{ area.scrollTop++; if(area.scrollTop >= area.scrollHeight/2){ area.scrollTop =0; } } } //页面加载两秒后运动 setTimeout(startScroll,delay) //鼠标事件 $("#scrollBox").mouseover(function(){clearInterval(timer)}); $("#scrollBox").mouseout(function(){timer=setInterval('scrollUp()',speed)}); </script> </body> </html>
注意1:必须要注意,html文档的加载顺序,必须要保证,js在文档加载后执行
效果:
速度和一次滚动的条目数,可以在代码中修改
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- java-WEB中的监听器Lisener
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- GUI - Web前端开发框架
- Extjs4.0 最新最全视频教程
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- MyEclipse Web Project转Eclipse Dynamic Web Project
- axis备忘
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因