Я пробовал около 5 реализаций анимации роутер-аутлет.Я просто хочу базовую анимацию постепенного появления / исчезновения, когда маршрут меняется, ничего особенного.
Вот экранная запись того, как все выглядит, когда я переключаю маршрут: https://streamable.com/tbkxt
Это лучший результат, который я получил, в других случаях у меня просто были кнопки / текстисчезают с экрана по одному.Я тестирую в Chrome.
У меня включена навигация по sidenav, и мой код выглядит следующим образом:
<mat-sidenav-content [@routerTransition]="getPageTransition(routerOutlet)">
<button
@menu-button
*ngIf="!snav.opened"
mat-button
(click)="snav.toggle()"
class="navigation-toggle"
>
<fa-icon icon="bars"></fa-icon>
</button>
<button
@menu-button
*ngIf="snav.opened"
mat-button
(click)="snav.toggle()"
class="navigation-toggle"
>
<fa-icon icon="times"></fa-icon>
</button>
<router-outlet #routerOutlet="outlet"></router-outlet>
</mat-sidenav-content>
Мои анимации определены:
const query = (style, animate, optional = { optional: true }) =>
q(style, animate, optional);
const fade = [
query(':enter, :leave', style({ position: 'fixed', width: '100%' })),
query(':enter', [style({ opacity: 0 })]),
group([
query(':leave', [animate('0.3s ease-out', style({ opacity: 0 }))]),
query(':enter', [
style({ opacity: 0 }),
animate('0.3s ease-out', style({ opacity: 1 }))
])
])
];
export const routerTransition = trigger('routerTransition', [
transition('void => *', [
style({ top: '0px', opacity: 0 }),
animate(2000, style({ top: '0px', opacity: 1 }))
]),
transition('* => void', [
style({ top: '0px', opacity: 1 }),
animate(2000, style({ top: '0px', opacity: 0 }))
]),
transition('* => forward', fade),
transition('* => backward', fade)
]);
И вкомпонент проверяю розетку роутера:
getPageTransition(routerOutlet: RouterOutlet) {
if (routerOutlet.isActivated) {
let transitionName = 'section';
const { path } = routerOutlet.activatedRoute.routeConfig;
const isSame = this.previousPath === path;
const isBackward = this.previousPath.startsWith(path);
const isForward = path.startsWith(this.previousPath);
if (isSame) {
transitionName = 'none';
} else if (isBackward && isForward) {
transitionName = 'initial';
} else if (isBackward) {
transitionName = 'backward';
} else if (isForward) {
transitionName = 'forward';
}
this.previousPath = path;
return transitionName;
}