从安
2019-06-21
来源 :
阅读 2392
评论 0
摘要:本篇文章主要讲述JavaScript之快速掌握列表内容自动向上滚动(原生JS),希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。
本篇文章主要讲述JavaScript之快速掌握列表内容自动向上滚动(原生JS),希望阅读本篇文章以后大家有所收获,帮助大家对相关内容的理解更加深入。

实现原理
1. html结构:核心是ul > li,ul外层包裹着div。因为想要内容循环滚动无缝衔接,所以在原有ul后面还要有一个一样内容的ul。如下图:
(红色边框为可视区域div,此处为了方便查看效果去除overflow:hidden;)
2. 样式方面:由于要滚动,所以必须2个ul的高度 > 外层可视div高度,且div必须设置overflow:hidden;
代码实现
HTML:
1 <div id="review_box"> 2 <ul id="comment1"> 3 <li>第一条</li> 4 <li>第二条</li> 5 <li>第三条</li> 6 <li>第四条</li> 7 <li>第五条</li> 8 <li>第六条</li> 9 </ul> 10 <ul id="comment2"></ul> 11 </div>
CSS:
1 * {
2 margin: 0;
3 padding: 0;
4 }
5 div {
6 width: 100px;
7 height: 63px; /* 必须 */
8 overflow: hidden;/* 必须 */
9 margin: 50px auto;
10 border: 1px solid red;
11 text-align: center;
12 }
13 ul {
14 list-style: none;
15 }
JavaScript:
1 window.onload = roll(50);
2
3 function roll(t) {
4 var ul1 = document.getElementById("comment1");
5 var ul2 = document.getElementById("comment2");
6 var ulbox = document.getElementById("review_box");
7 ul2.innerHTML = ul1.innerHTML;
8 ulbox.scrollTop = 0; // 开始无滚动时设为0
9 var timer = setInterval(rollStart, t); // 设置定时器,参数t用在这为间隔时间(单位毫秒),参数t越小,滚动速度越快
10 // 鼠标移入div时暂停滚动
11 ulbox.onmouseover = function () {
12 clearInterval(timer);
13 }
14 // 鼠标移出div后继续滚动
15 ulbox.onmouseout = function () {
16 timer = setInterval(rollStart, t);
17 }
18 }
19
20 // 开始滚动函数
21 function rollStart() {
22 // 上面声明的DOM对象为局部对象需要再次声明
23 var ul1 = document.getElementById("comment1");
24 var ul2 = document.getElementById("comment2");
25 var ulbox = document.getElementById("review_box");
26 // 正常滚动不断给scrollTop的值+1,当滚动高度大于列表内容高度时恢复为0
27 if (ulbox.scrollTop >= ul1.scrollHeight) {
28 ulbox.scrollTop = 0;
29 } else {
30 ulbox.scrollTop++;
31 }
32 }本文由职坐标整理发布,学习更多的相关知识,请关注职坐标IT知识库!
喜欢 | 0
不喜欢 | 0
您输入的评论内容中包含违禁敏感词
我知道了

请输入正确的手机号码
请输入正确的验证码
您今天的短信下发次数太多了,明天再试试吧!
我们会在第一时间安排职业规划师联系您!
您也可以联系我们的职业规划师咨询:
版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
沪公网安备 31011502005948号