html
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport"
content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>跑马灯</title>
<style>
* {
margin: 0;
padding: 0;
}
ul, li {
list-style: none;
}
.box {
margin: 40px auto;
width: 800px;
height: 200px;
border: 1px dashed #00b38a;
overflow: hidden;
}
.box ul {
height: 200px;
}
.box ul li {
float: left;
width: 200px;
height: 200px;
}
.box ul li img { /*一般设置图片的时候都是给图片包一个块元素,然后设置块元素的宽高,让里面的图片
宽高都是100%*/
width: 100%;
height: 100%;
}
.clearfix:after {
display: block;
content: '';
height: 0;
visibility: hidden;
clear: both;
}
</style>
</head>
<body>
<div class="box" id="box">
<ul class="ulBox clearfix" id="ulBox">
<li><img src="img/1.jpg" alt=""></li>
<li><img src="img/2.jpg" alt=""></li>
<li><img src="img/3.jpg" alt=""></li>
<li><img src="img/4.jpg" alt=""></li>
</ul>
</div>
<script src="1-跑马灯.js"></script>
</body>
</html>
js
// 1. 获取元素
let box = document.querySelector('#box');
// console.log(box);
// 2. 复制一份li
let ulBox = document.querySelector('#ulBox');
ulBox.innerHTML += ulBox.innerHTML; // 复制一份 html,并且插入到页面中
// 3. 为了让这些图片在一行,重新调整 ul 的宽度
ulBox.style.width = '1600px'; // 有单位 px
// 4. 滚动起来
let timer = setInterval(() => {
box.scrollLeft += 1;
if (box.scrollLeft >= 800) {
box.scrollLeft = 0;
}
}, 16);
// 当浏览器窗口处于最小化时,浏览器中定时器计时可能会出现问题。是因为最小化的过程中,浏览器进入了节能的状态,计算会出现偏差。
// 切换页卡也可能会导致这种情况;
// webWorker 可以启动另一个线程,某些情况下可以用这个解决这些问题;
图片素材
1.jpg2.jpg3.jpg4.jpg