最近看到一个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,来达到动画效果