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. 复制一份lilet 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