事件触发css 动画,js处理css3 transitionend和animationend动画事件

之前的文章中已经测试了transform、transitionend、animationend在移动和pc端浏览器的前缀的兼容问题((针对pc和移动浏览器的前缀问题),如果知道了兼容问题,下面的代码就可以很好理解,现在整理了一下,写成一个简单的原声 js函数,这个函数方法有:

1、addTranEvent(elem,fn,duration):用于绑定transtionend事件,处理掉多次执行的问题

2、addAnimEvent(elem,fn),removeAnimEvent(elem,fn):分别用于绑定和解绑animationend事件

3、setStyleAttribute(elem,val):用于设置css3的属性

通过将之前的文章的代码整理一下,代码不多也很好理解,具体如下:

(function (root, factory) {

if (typeof define === 'function') {

define(factory);

}else if (typeof exports === 'object') {

module.exports = factory;

} else {

root.WN = factory();

}

})(this,function(){

var WN = {},

body=document.body || document.documentElement,

style=body.style,

transition="transition",

transitionEnd,

animationEnd,

vendorPrefix;

transition=transition.charAt(0).toUpperCase() + transition.substr(1);

vendorPrefix=(function(){//现在的opera也是webkit

var  i=0, vendor=["Moz", "Webkit", "Khtml", "O", "ms"];

while (i < vendor.length) {

if (typeof style[vendor[i] + transition] === "string") {

return vendor[i];

}

i++;

}

return false;

})();

transitionEnd=(function(){

var transEndEventNames = {

WebkitTransition : 'webkitTransitionEnd',

MozTransition    : 'transitionend',

OTransition      : 'oTransitionEnd otransitionend',

transition       : 'transitionend'

}

for(var name in transEndEventNames){

if(typeof style[name] === "string"){

return transEndEventNames[name]

}

}

})();

animationEnd=(function(){

var animEndEventNames = {

WebkitAnimation : 'webkitAnimationEnd',

animation      : 'animationend'

}

for(var name in animEndEventNames){

if(typeof style[name] === "string"){

return animEndEventNames[name]

}

}

})();

WN.addTranEvent=function(elem,fn,duration){

var called=false;

var fncallback = function(){

if(!called){

fn();

called=true;

}

};

function hand(){

elem.addEventListener(transitionEnd, function () {

elem.removeEventListener(transitionEnd, arguments.callee, false);

fncallback();

}, false);

}

setTimeout(hand,duration);

};

WN.addAnimEvent=function(elem,fn){

elem.addEventListener(animationEnd,fn,false)

};

WN.removeAnimEvent=function(elem,fn){

elem.removeEventListener(animationEnd,fn,false)

};

WN.setStyleAttribute=function(elem,val){

if(Object.prototype.toString.call(val)==="[object Object]"){

for(var name in val){

if(/^transition|animation|transform/.test(name)){

var styleName=name.charAt(0).toUpperCase() + name.substr(1);

elem.style[vendorPrefix+styleName]=val[name];

}else{

elem.style[name]=val[name];

}

}

}

};

WN.transitionEnd=transitionEnd;

WN.vendorPrefix=vendorPrefix;

WN.animationEnd=animationEnd;

return WN;

});

代码就是上面那些,就是根据浏览器的前缀来获取属性,然后去设置我们想要的结果,下面用三个demo分别来演示一下:

1、transitionend事件

transitionPlu
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值