本文详解如何修复 javascript 中因变量名错误和 css 属性误用导致的旋转失效问题,提供可复用的 dom 元素批量旋转方案,并强调 `transform: rotate()` 的正确用法与状态管理要点。
在前端交互开发中,常需通过点击触发图形旋转动画。但初学者易陷入两个典型错误:一是混淆变量名(如将 Degree 写成未声明的 deg),二是误用非标准 CSS 属性(如 style.rotate 而非 style.transform)。上述代码中,ReferenceError: deg is not defined 正源于此——deg 从未声明,而真正累加的是 Degree 变量。
此外,document.getElementsByTagName('div') 返回的是 HTMLCollection,使用 for...in 遍历会意外包含原型属性(如 length、item 等),导致运行时错误或不可预期行为。更可靠的方式是使用 document.querySelectorAll('.example') 获取 NodeList,并配合 forEach() 安全遍历。
以下是修正后的完整实现:
点击旋转所有形状
✅ 关键修正点总结:
⚠️ 注意事项:
通过以上优化,即可稳定、可维护地实现点击触发多元素同步旋转的效果。