为了账号安全,请及时绑定邮箱和手机立即绑定

使用jquery.animate()的CSS旋转跨浏览器

使用jquery.animate()的CSS旋转跨浏览器

绝地无双 2019-10-16 12:57:04
我正在创建跨浏览器兼容的旋转(ie9 +),并且在jsfiddle中有以下代码$(document).ready(function () {     DoRotate(30);    AnimateRotate(30);});function DoRotate(d) {    $("#MyDiv1").css({          '-moz-transform':'rotate('+d+'deg)',          '-webkit-transform':'rotate('+d+'deg)',          '-o-transform':'rotate('+d+'deg)',          '-ms-transform':'rotate('+d+'deg)',          'transform': 'rotate('+d+'deg)'     });  }function AnimateRotate(d) {        $("#MyDiv2").animate({          '-moz-transform':'rotate('+d+'deg)',          '-webkit-transform':'rotate('+d+'deg)',          '-o-transform':'rotate('+d+'deg)',          '-ms-transform':'rotate('+d+'deg)',          'transform':'rotate('+d+'deg)'     }, 1000); }CSS和HTML非常简单,仅用于演示:.SomeDiv{    width:50px;    height:50px;           margin:50px 50px;    background-color: red;}<div id="MyDiv1" class="SomeDiv">test</div><div id="MyDiv2" class="SomeDiv">test</div>使用时旋转有效,.css()但使用时无效.animate(); 为什么会这样,有没有办法解决?谢谢。
查看完整描述

3 回答

?
繁花不似锦

TA贡献1851条经验 获得超4个赞

如果您通过jQuery处理CSS3动画,那么jQuery过渡可能会使您的生活更轻松。


EDIT 2014年3月 (因为自从我发表建议以来,我的建议一直在上下投票)


让我解释一下为什么我最初暗示上面的插件:


就性能而言,更新DOM每个步骤(即$.animate)都不理想。它可以工作,但很可能会比纯CSS3过渡或CSS3动画慢。


这主要是因为,如果您指出从头到尾的过渡情况,浏览器将有机会思考。


为此,例如,您可以为过渡的每个状态创建一个CSS类,并且仅使用jQuery切换动画状态。


通常这很整洁,因为您可以调整动画以及CSS的其余部分,而不必将其与业务逻辑混合在一起:


// initial state

.eye {

   -webkit-transform: rotate(45deg);

   -moz-transform: rotate(45deg);

   transform: rotate(45deg);

   // etc.


   // transition settings

   -webkit-transition: -webkit-transform 1s linear 0.2s;

   -moz-transition: -moz-transform 1s linear 0.2s;

   transition: transform 1s linear 0.2s;

   // etc.

}


// open state    

.eye.open {


   transform: rotate(90deg);

}


// Javascript

$('.eye').on('click', function () { $(this).addClass('open'); });

如果任何变换参数是动态的,那么您当然可以改用style属性:


$('.eye').on('click', function () { 

    $(this).css({ 

        -webkit-transition: '-webkit-transform 1s ease-in',

        -moz-transition: '-moz-transform 1s ease-in',

        // ...


        // note that jQuery will vendor prefix the transform property automatically

        transform: 'rotate(' + (Math.random()*45+45).toFixed(3) + 'deg)'

    }); 

});

有关MDN上CSS3过渡的更多详细信息。


但是,还需要记住其他一些事项,如果您具有复杂的动画,链接等,所有这些都会变得有些棘手,而jQuery Transit只是在幕后做了所有棘手的工作:


$('.eye').transit({ rotate: '90deg'}); // easy huh ?


查看完整回答
反对 回复 2019-10-16
  • 3 回答
  • 0 关注
  • 1178 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信