分享一个CSS3动画效果设置的函数(兼容所有浏览器)

最近看到一个CSS3动画设置的方法,分享一下:

function setCss3 (obj,attrObj) { 
//其中obj是被设置的对象,attrObj是json格式的CSS3设置,attrObj设置的时候不用写浏览器头
   for (var i in attrObj) {
         var newi=i;
     if(newi.indexOf("-")>0){
//如果里面有transition-duration这样的CSS3属性时,把“-”去掉,并且大写“-”第一个字母,最后形成transitionDuration
         var num=newi.indexOf("-");
         newi=newi.replace(newi.substr(num,2),newi.substr(num+1,1).toUpperCase());
     }
//默认的不考虑浏览器兼容的写法。
     obj.style[newi]=attrObj[i];
//如果没有"-",也会把第一个字母大写,因为前面要添加浏览器前缀
     newi=newi.replace(newi.charAt(0),newi.charAt(0).toUpperCase());
     obj.style["webkit"+newi]=attrObj[i];
     obj.style["moz"+newi]=attrObj[i];
     obj.style["o"+newi]=attrObj[i];
     obj.style["ms"+newi]=attrObj[i];
   }
  }

使用时:

setCss3(boxs,{transform:"rotateY("+angle+"deg)"})
//通过动态设置angle,来达到动画效果
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,261评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,196评论 4 61
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,681评论 1 92
  • 最近在刷郭德纲的一些作品,其中有一段视屏,采访中他话糙理不糙,说了一下关于吃亏的认识: 记者问到:活明白需要时间的...
    风shuo阅读 3,073评论 0 2
  • 人的心 不是所谓慢慢就看到了的 而是 在别人的口中诉说 然后自己看到 这样才算的上真正的慢慢看到 你以为的坚不可摧...
    loole阅读 1,014评论 0 0