最近用angular4写项目需要为每次路由跳转增加动画,看了一下官方文档,虽然可以实现,但是要每个组件都引入一次animations,比较麻烦,找网上也查阅了很多资料,但是都没找到适用的方法,最后自己写了一种方法如下:
首先在app.module中导入BrowserAnimationsModule
import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; @NgModule({ imports: [ BrowserAnimationsModule
在根目录src/app/下创建一个animations.ts。内容如下,这里我用到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 设置每次路由跳转监听的参数变化并且引入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跳转动画所需参数 routerState: boolean = true; routerStateCode: string = 'active'; this.router.events.subscribe(event => { if (event instanceof NavigationEnd) { // 每次路由跳转改变状态 this.routerState = !this.routerState; this.routerStateCode = this.routerState "htmlcode"><div id="app" [@routeAnimation]="routerStateCode"> <router-outlet></router-outlet> </div>现在全局路由跳转都有动画了,不用一个一个组件导入animations。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“angular4 如何在全局设置路由跳转动画的方法”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
20240727
20240727
- 丁当《日与夜,跟自己说晚安》[320K/MP3][98.51MB]
- 何炅.2005-漫游【中唱】【WAV+CUE】
- 何嘉莉.1998-MYDREAMS(EP)【飞图】【WAV+CUE】
- 群星.2019-天坑鷹猎电视剧原声带(EP)【智慧大狗】【FLAC分轨】
- 【雨果唱片】《春江花月夜》2020【WAV+CUE】
- 【正原唱片】女子十二乐坊《发烧国乐精粹-十二乐坊》WAV+CUE
- [黄翠珊]SusanWong-TheBestofSusanWong[WAV+CUE]
- 杜德伟.1995-BEST.LOVE(英)【滚石】【WAV+CUE】
- 杜德伟.1996-BEST.LOVE.2(英)【滚石】【WAV+CUE】
- 陈柏宇.2008-Change【SONY】【FLAC分轨】
- 丁当《日与夜,跟自己说晚安》[FLAC/分轨][285.42MB]
- 早安《Bubble Vision》[320KMP3][36.83MB]
- 叶振棠《叶振棠歌曲合集》[合集][MP3][145.9MB]
- [黄翠珊]SusanWong-ClosetoMe[SACD]dsf
- 中唱唱片群星《好歌珍藏-民歌精粹》2CD[WAV.]