var int = self.setInterval("mOut()",3000); function mOut(){ inner.style.transform="rotateY("+360+"deg)"; inner.style.transition = "transform 3s"; }优化代码
时间: 2023-11-20 15:06:23 浏览: 98
可以将定时器的回调函数直接传入 setInterval 中,避免使用字符串形式,同时可以将 inner.style.transform 和 inner.style.transition 合并为一行,避免多次操作 DOM。优化后的代码如下:
```
var int = setInterval(function() {
inner.style.cssText = "transform: rotateY(360deg); transition: transform 3s;";
}, 3000);
```
另外,建议将变量名 int 改为更具描述性的名称。
相关问题
var inner = document.getElementsByClassName('inner'); // onmouseover="mOver(this)" onmouseout="mOut(this)" // aEle[i].style.transform = "rotateY(" + (i * (360 / aEle.length)) + "deg) translateZ(" + radius + "px)"; var int = self.setInterval("mOut()",3000); function mOut(){ inner.style.transform="rotateY("+360+"deg)"; inner.style.transition = "transform 3s"; }优化代码
首先,`setInterval`中传递的参数应该是一个函数名或函数表达式,而不是一个字符串。所以应该将`setInterval`的参数改为`setInterval(mOut, 3000)`。
另外,`getElementsByClassName`返回的是一个HTMLCollection,而不是一个单独的元素。因此,应该使用`inner[0]`来获取第一个匹配的元素。
最后,`mOut`函数中的`rotateY`值应该是相对于当前的值进行旋转,而不是固定的360度。所以应该先获取当前的rotateY值,再加上360度。
优化后的代码如下:
```
var inner = document.getElementsByClassName('inner')[0];
var int = setInterval(mOut, 3000);
function mOut() {
var currentRotation = parseInt(inner.style.transform.replace(/[^0-9\-]/g, ''));
inner.style.transform = "rotateY(" + (currentRotation + 360) + "deg)";
inner.style.transition = "transform 3s";
}
```
var ball = document.querySelector('.ball'); var x = 0; setInterval(function(){ x++; ball.style.left = x + 'px'; },16);
你的代码几乎是正确的,只有一个小错误。在设置小球的位置时,你使用了 `ball.style.left`,但是在变量声明时你使用了 `var ball = document.querySelector('.ball');`。这导致了一个未定义的变量错误。
下面是修正后的代码:
```javascript
var ball = document.querySelector('.ball');
var x = 0;
setInterval(function() {
x++;
ball.style.left = x + 'px';
}, 16);
```
这段代码将获取到具有类名为 "ball" 的元素,并使用 `setInterval` 每 16 毫秒将小球向右移动一像素。通过修改 `ball.style.left` 的值,可以实现小球的水平移动效果。
请确保在 HTML 中存在具有类名为 "ball" 的元素,并且该元素的样式中包含 `position: absolute;` 属性,以便使动画正常工作。
阅读全文