角度路由器动画定时错误

时间:2017-06-14 18:57:26

标签: angular angular-animations angular-router

我最近将我的Angular应用更新为4.0,以便利用路线之间的动画。

下面是我的动画功能:

export function routerTransition() {
    return trigger('routerAnimations', [
        transition('home => development, design => home', [
            query(':enter, :leave', style({ position: 'absolute', top: 0, left: 0, right: 0 })),
            query(':leave', style({ zIndex: 100 })),
            query(':enter', style({ transform: 'translateX(100%)', opacity:1 })),
            group([
                query(':leave', group([
                    animate('0.7s cubic-bezier(0.68, -0.75, 0.265, 1.55)', style({ transform: 'translateX(-100%)', opacity:0 }))
                ])),
                query(':enter', group([
                    animate('0.7s cubic-bezier(0.68, -0.75, 0.265, 1.55)', style({ transform: 'translateX(0%)' }))
                ]))
            ])
        ]),
        transition('home => design, development => home', [
            query(':enter, :leave', style({ position: 'absolute', top: 0, left: 0, right: 0 })),
            query(':leave', style({ zIndex: 100 })),
            query(':enter', style({ transform: 'translateX(-100%)', opacity:1 })),
            group([
                query(':leave', group([
                    animate('0.8s cubic-bezier(0.68, -0.75, 0.265, 1.55)', style({ transform: 'translateX(100%)', opacity:0 }))
                ])),
                query(':enter', group([
                    animate('0.8s cubic-bezier(0.68, -0.75, 0.265, 1.55)', style({ transform: 'translateX(0%)' }))
                ]))
            ])
        ])
    ])
}

出于某种原因,当我将一个转换的时间更改为与另一个转换的时间相同时(即将“0.7s”更改为“0.8s”),我收到以下错误:

The CSS property "transform" that exists between the times of "0ms" and "800ms" is also being animated in a parallel animation between the times of "0ms" and "800ms" 

两个动画不应重叠,因为每个过渡的stateChangeExpr都不同。

我错过了什么?

2 个答案:

答案 0 :(得分:0)

我有同样的问题,这似乎是一个错误。重新排序转换为我修复了它。

答案 1 :(得分:0)

我实际上能够让你的动画工作。为了解决这些问题,我:

  1. 删除了嵌套组(您有定义单个动画的组中的组)
  2. 我明确定义了您动画的每个属性的初始状态。如果您设置了动画translateX,我会在该元素的动画顶部设置起始值。
  3. 看起来您的初始不透明度值设置在错误的元素上(即您在:enter上将其设置为1,然后在:leave上设置为0。
  4. 以下是适合我的修订过渡:

    首先:

    query(':enter, :leave', style({ position: 'absolute', top: 0, left: 0, right: 0 })),
    query(':leave', style({ transform: 'translateX(0%)', opacity:1 })),
    query(':enter', style({ transform: 'translateX(100%)' })),
    
    group([
      query(':leave',
        animate('0.7s cubic-bezier(0.68, -0.75, 0.265, 1.55)',
        style({ transform: 'translateX(-100%)', opacity:0 }))
      ),
      query(':enter',
        animate('0.7s cubic-bezier(0.68, -0.75, 0.265, 1.55)',
        style({ transform: 'translateX(0%)' }))
      )
    ])
    

    第二

    query(':enter, :leave', style({ position: 'absolute', top: 0, left: 0, right: 0 })),
    query(':leave', style({ transform: 'translateX(0%)', opacity:1 })),
    query(':enter', style({ transform: 'translateX(-100%)' })),
    
    group([
      query(':leave',
        animate('0.7s cubic-bezier(0.68, -0.75, 0.265, 1.55)',
        style({ transform: 'translateX(100%)', opacity:0 }))
      ),
      query(':enter',
        animate('0.7s cubic-bezier(0.68, -0.75, 0.265, 1.55)',
        style({ transform: 'translateX(0%)' }))
      )
    ])