angular4 如何在全局設置路由跳轉(zhuǎn)動畫的方法
最近用angular4寫項目需要為每次路由跳轉(zhuǎn)增加動畫,看了一下官方文檔,雖然可以實現(xiàn),但是要每個組件都引入一次animations,比較麻煩,找網(wǎng)上也查閱了很多資料,但是都沒找到適用的方法,最后自己寫了一種方法如下:
首先在app.module中導入BrowserAnimationsModule
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
@NgModule({
imports: [
BrowserAnimationsModule
在根目錄src/app/下創(chuàng)建一個animations.ts。內(nèi)容如下,這里我用到query和group是想兩個頁面來回切換有過度痕跡
import { AnimationEntryMetadata, state } from '@angular/core';
import { trigger, transition, animate, style, query, group } from '\@angular/animations';
export const routeAnimation: AnimationEntryMetadata =
trigger('routeAnimation', [
transition(':enter', [
style({
position: 'absolute'
}),
animate('0.5s ease-in-out')
]),
transition('* => *', [
query(':leave', style({ transform: 'translateX(0)', position: 'absolute'}), { optional: true }),
query(':enter', style({ transform: 'translateX(100%)', position: 'absolute'}), { optional: true }),
group([
query(':leave', animate('.5s ease-in-out', style({transform: 'translateX(-100%)'})), { optional: true }),
query(':enter', animate('.5s ease-in-out', style({transform: 'translateX(0)'})), { optional: true })
])
])
]);
接著在app.component中使用 NavigationEnd 設置每次路由跳轉(zhuǎn)監(jiān)聽的參數(shù)變化并且引入animations模塊
import { Router, NavigationEnd } from '@angular/router';
import { routeAnimation } from './animations';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.less'],
animations: [routeAnimation]
})
// router跳轉(zhuǎn)動畫所需參數(shù)
routerState: boolean = true;
routerStateCode: string = 'active';
this.router.events.subscribe(event => {
if (event instanceof NavigationEnd) {
// 每次路由跳轉(zhuǎn)改變狀態(tài)
this.routerState = !this.routerState;
this.routerStateCode = this.routerState ? 'active' : 'inactive';
}
});
最后在app.component.html中聲明路由動畫就可以了
<div id="app" [@routeAnimation]="routerStateCode"> <router-outlet></router-outlet> </div>
現(xiàn)在全局路由跳轉(zhuǎn)都有動畫了,不用一個一個組件導入animations。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
深入理解Angularjs中$http.post與$.post
本篇文章主要介紹了深入理解Angularjs中$http.post與$.post ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
AngularJs定時器$interval 和 $timeout詳解
這篇文章主要介紹了AngularJs定時器$interval 和 $timeout詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
angular學習之動態(tài)創(chuàng)建表單的方法
這篇文章主要介紹了angular學習之動態(tài)創(chuàng)建表單的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
Angularjs根據(jù)json文件動態(tài)生成路由狀態(tài)的實現(xiàn)方法
最近做項目遇到這樣一個新需求,就是需要根據(jù)json文件動態(tài)生成路由狀態(tài),通過查閱相關資料實現(xiàn)了此功能,下面小編把問題總結(jié)分享到腳本之家平臺供大家參考2017-04-04

