>  기사  >  웹 프론트엔드  >  완화 효과를 위한 Node.js 구현 예제 코드

완화 효과를 위한 Node.js 구현 예제 코드

零下一度
零下一度원래의
2017-07-20 09:25:521176검색
var tween = {
    linear:function(t,b,c,d){return c*t/d + b;    },
    easeIn:function(t,b,c,d){return c * ( t /= d ) * t + b;    },
    strongEaseIn:function(t,b,c,d){return c * ( t /= d ) * t * t * t * t + b;    },
    strongEaseOut:function(t,b,c,d){return c * ( ( t = t / d -1 ) * t * t * t * t +1 ) + b;
    },
    sineaseIn:function(t,b,c,d){return c * ( t /= d ) * t * t + b;    
    },
    sineaseOut:function(t,b,c,d){return c * ( ( t = t / d -1 ) * t * t *t +1 ) + b;
    }
};var Animate = function(dom){this.dom = dom;this.startTime = 0;this.startPos = 0;this.endPos = 0;this.propertyName = null;this.easing = null;this.duration = null;
}

Animate.prototype.start = function(propertyName,endPos,duration,easing){this.startTime = +new Date;this.startPos = this.dom.getBoundingClientRect()[propertyName];this.propertyName = propertyName;this.endPos = endPos;this.duration = duration;this.easing = tween[easing];var self = this;var timeId = setInterval(function(){if(self.step() === false){
            clearInterval(timeId);
        }
    },19);
}

Animate.prototype.step = function(){var t = +new Date;if(t>=this.startTime + this.duration){this.update(this.endPos);return false;
    }var pos = this.easing(t-this.startTime, this.startPos, this.endPos - this.startPos, this.duration);this.update(pos);
}

Animate.prototype.update = function(pos){this.dom.style[this.propertyName] = pos + 'px';
}var div = document.getElementById('div');var animate = new Animate(div);
animate.start('left',500,1000,'strongEaseOut');

 

위 내용은 완화 효과를 위한 Node.js 구현 예제 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.