使用 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 FlexBox,这是一种布局方法,用于有效地对齐和分布响应设计中的空间。它说明了FlexBox用法,将其与CSS网格进行了比较,并详细浏览了浏览器支持。

本文讨论了使用CSS创建响应网站的技术,包括视口元标签,灵活的网格,流体媒体,媒体查询和相对单元。它还涵盖了使用CSS网格和Flexbox一起使用,并推荐CSS框架

本文讨论了CSS盒装属性,该属性控制了元素维度的计算方式。它解释了诸如Content-Box,Border-Box和Padding-Box之类的值,以及它们对布局设计和形式对齐的影响。


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

禅工作室 13.0.1
功能强大的PHP集成开发环境

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

Atom编辑器mac版下载
最流行的的开源编辑器