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