使用 jQuery.animate() 进行跨浏览器 CSS 旋转
问题:
执行使用 jQuery.animate() 的 CSS 旋转动画无法跨浏览器工作。使用 .css() 时旋转有效,但使用 .animate() 时则无效。
原因:
CSS-Transforms 无法直接使用 jQuery 进行动画处理。
解决方案:
执行使用 jQuery 进行 CSS-Transform 动画,可以使用以下替代方法:
function AnimateRotate(angle) { var $elem = $('#MyDiv2'); $({deg: 0}).animate({deg: angle}, { duration: 2000, step: function(now) { $elem.css({ transform: 'rotate(' + now + 'deg)' }); } }); }
说明:
此方法使用自定义的“step”回调函数来更新动画每个步骤中所选元素的“transform”属性。 “step”函数接收当前动画位置(现在)作为参数,您可以使用它来计算所需的旋转角度。
插件:
您可以将此方法封装到 jQuery 插件中以方便使用使用:
$.fn.animateRotate = function(angle, duration, easing, complete) { return this.each(function() { var $elem = $(this); $({deg: 0}).animate({deg: angle}, { duration: duration, easing: easing, step: function(now) { $elem.css({ transform: 'rotate(' + now + 'deg)' }); }, complete: complete || $.noop }); }); };
用法:
要使用该插件,您只需调用:
$('#MyDiv2').animateRotate(90);
更新:
提供的解决方案已更新多次,以提高效率并提供更多灵活性。
- 更新 2:优化以使参数的顺序无关紧要。
- 更新 2.1:修复了上下文问题完成回调。
- 更新2.2:添加了用于切换动画的启动参数。
其他使用详细信息:
- animateRotate 函数接受多个可选参数,包括持续时间、缓动和完整,并提供默认值。
- 用户可以通过多种方式提供这些参数,无论是位置参数参数或作为对象。
- “step”函数提供对每个动画步骤的旋转的额外控制。
以上是如何使用 jQuery 实现跨浏览器 CSS 旋转动画?的详细内容。更多信息请关注PHP中文网其他相关文章!

CSS盒子阴影和轮廓属性获得了主题。让我们查看一些在真实主题中起作用的示例,以及我们必须将这些样式应用于WordPress块和元素的选项。

Svelte Transition API提供了一种使组件输入或离开文档(包括自定义Svelte Transitions)时动画组件的方法。

前几天我只是和埃里克·迈耶(Eric Meyer)聊天,我想起了我成长时代的埃里克·迈耶(Eric Meyer)的故事。我写了一篇有关CSS特异性的博客文章,以及


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SublimeText3汉化版
中文版,非常好用

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能