From 267aa32f5a56777e36818ffc918346cc9d744817 Mon Sep 17 00:00:00 2001 From: "Manu Mtz.-Almeida" Date: Thu, 30 Jun 2016 15:17:17 +0200 Subject: [PATCH] perf(animation): using will-change when using progressStep() --- src/animations/animation.ts | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/src/animations/animation.ts b/src/animations/animation.ts index 19e1ed90667..b51547110ee 100644 --- a/src/animations/animation.ts +++ b/src/animations/animation.ts @@ -618,16 +618,21 @@ export class Animation { } if (Object.keys(this._fx).length) { + easing = (forcedLinearEasing ? 'linear' : this.getEasing()); for (i = 0; i < this._el.length; i++) { - // all parent/child animations should have the same duration - // ******** DOM WRITE **************** - this._el[i].style[CSS.transitionDuration] = duration + 'ms'; - - // each animation can have a different easing - easing = (forcedLinearEasing ? 'linear' : this.getEasing()); - if (easing) { + if (duration > 0) { + // all parent/child animations should have the same duration // ******** DOM WRITE **************** - this._el[i].style[CSS.transitionTimingFn] = easing; + this._el[i].style[CSS.transition] = ''; + this._el[i].style[CSS.transitionDuration] = duration + 'ms'; + + // each animation can have a different easing + if (easing) { + // ******** DOM WRITE **************** + this._el[i].style[CSS.transitionTimingFn] = easing; + } + } else { + this._el[i].style[CSS.transition] = 'none'; } } } @@ -824,6 +829,9 @@ export class Animation { this._c[i].progressStart(); } + // ******** DOM WRITE **************** + this._willChg(true); + // ******** DOM WRITE **************** this._before();