ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 盒子自动向右移动,到达最右边,开始返回移动,再重复 ``` <style> *{ margin:0; padding: 0; } #div{ width: 100px; height:100px; background-color: #f00; position: absolute; /* left:100px; */ } button{ position: relative; top:120px; } </style> <div id="div"></div> <button>点击开始</button> <button>点击停止</button> <script> // 逻辑:1.一个元素动起来,其实就是位置的移动 // 2.连续动起来,需要一个定时器的 (有一个开关才行,为了防止多个定时器累积) // 3.需要对移动做条件 (当移动距离大于body宽度或小于0) // 当满足两个条件 做相反移动 let buts = document.getElementsByTagName('button'); let div = document.getElementById('div'); let body = document.body; let num = 0; let timer = null; buts[0].onclick = function(){ // 声明一个变量speed,也就是移动的速度 let speed = 5; if(timer==null){ timer = setInterval(()=>{ num += speed;//移动速度 div.style.left = num+'px';//元素真正移动的核心 // 当移动距离大于body宽度或小于0 if(num>=body.offsetWidth-div.offsetWidth || num<=0){ // 速度变量取反 speed = -speed; } },100); } } buts[1].onclick = function(){ clearInterval(timer); timer=null; } </script> ``` ![](https://img.kancloud.cn/76/ea/76eab1d0774b1f965b84e0a22821c26b_750x312.png)