1、为什么有的人路由转动效离场动效不生效?

自己研究发现是加动效的位置放错了  如下:

<---! animate-state.component.html -->
<div style="background-color: antiquewhite;width: 100vw" [@trigger] id="f">
style="background-color: antiquewhite;width: 100%;height: 100px;
</div>
//有的人可能会在组件内容的最顶层元素 加一个动效。以为这样能达到路由转场的效果,其实不然,因为组件本身才是这个组件的根元素。当通过路由转场时,
//离场的根元素瞬间就隐藏了,以有其组件里面的内容不管加什么动效也无用,有动效,元素隐藏了也看不到啊!
// 如上面的的html 模块名为:selector: 'app-animate-state',那么<app-animate-state></app-animate-state>是根元素,动画应该加在这样面才会有转场效果,而不是上面的组件内容最顶层元素

2、解决放法

  因为路由你是没法写代表一个路由内容<app-animate-state></app-animate-state>这个标签元素的。

那么怎么做了?如下

用 @HostBinding()绑定根元素,加上动效。

/路由切换动效如下

//animate-state.component.html
<div style="background-color: antiquewhite;width: 100vw">
style="background-color: antiquewhite;width: 100%;height: 100px;
</div> //animate-state.component.ts import {Component, HostBinding, OnInit} from '@angular/core';
import {trigger2} from "../animation/trigger"; @Component({
selector: 'app-animate-state',
templateUrl: './animate-state.component.html',
styleUrls: ['./animate-state.component.css'],
animations: [trigger2]
})
export class AnimateStateComponent implements OnInit { constructor() { }
@HostBinding('@trigger2') trigger2 = "";
ngOnInit() {
} } //animate-trigger.component.html
<div style="background-color: red;width: 100vw">
[@heroState] = 'name'
</div> //animate-trigger.component.ts import {Component, HostBinding, OnInit} from '@angular/core';
import {trigger1, trigger2} from "../animation/trigger"; @Component({
selector: 'app-animate-trigger',
templateUrl: './animate-trigger.component.html',
styleUrls: ['./animate-trigger.component.css'],
animations: [trigger1, trigger2]
})
export class AnimateTriggerComponent implements OnInit {
constructor() { }
@HostBinding('@trigger2') trigger2 = "";
ngOnInit() {
} }
//app.module.ts
const appRoutes: Routes = [
{ path: 'trigger', component: AnimateTriggerComponent },
{ path: 'state', component: AnimateStateComponent },
{ path: '',
redirectTo: '/trigger',
pathMatch: 'full'
},
{ path: '**', component: AnimateTriggerComponent }
];
//app.component.html <a routerLink="/trigger" routerLinkActive="active">trigger</a>
<a routerLink="/state" routerLinkActive="active">state</a> <div id="app">
<router-outlet></router-outlet>
</div> //trigger.ts 动效 export const trigger2 = trigger('trigger2', [
transition('* => void', [style({opacity: ,position: 'absolute'}),animate(,style({opacity: }))]),
transition('void => *', [style({opacity: ,position: 'absolute'}),animate(,style({opacity: }))])
]);

3、可是这样做的话,每个路由都要这样加,会显的很繁琐,在重复,有办法一次性全加上吗? 当然是有  如下: 用到动效里的query特性函数和路由中的NavigationEnd属性 代码如下

//animate-state.component.html
<div style="background-color: antiquewhite;width: 100vw">
style="background-color: antiquewhite;width: 100%;height: 100px;
</div> //animate-state.component.ts import {Component, HostBinding, OnInit} from '@angular/core'; @Component({
selector: 'app-animate-state',
templateUrl: './animate-state.component.html',
styleUrls: ['./animate-state.component.css'],
})
export class AnimateStateComponent implements OnInit { constructor() { }
ngOnInit() {
} } //animate-trigger.component.html
<div style="background-color: red;width: 100vw">
[@heroState] = 'name'
</div> //animate-trigger.component.ts import {Component, HostBinding, OnInit} from '@angular/core'; @Component({
selector: 'app-animate-trigger',
templateUrl: './animate-trigger.component.html',
styleUrls: ['./animate-trigger.component.css'],
})
export class AnimateTriggerComponent implements OnInit {
constructor() { }
ngOnInit() {
} }
//trigger.ts
import {
trigger,
state,
style,
animate,
transition, query, group
} from '@angular/animations';
import {AnimationEntryMetadata} from "@angular/core";
 export const routeAnimation1: AnimationEntryMetadata = trigger('routeAnimation1', [ transition('* => *', group([ query(':leave', animate('.5s', 
style({opacity: ,position: 'absolute'})), { optional: true }), query(':enter', [style({opacity: ,position: 'absolute'}),
animate('.5s', style({ opacity: }))],{ optional: true }) ]) ) ]); //app.module.ts
const appRoutes: Routes = [ { path: 'trigger', component: AnimateTriggerComponent },
{ path: 'state', component: AnimateStateComponent }, { path: '', redirectTo: '/trigger', pathMatch: 'full' } ]; //app.component.html <a routerLink="/trigger" routerLinkActive="active">trigger</a>
<a routerLink="/state" routerLinkActive="active">state</a>
<div id="app" [@routeAnimation1]="routerStateCode">
  <router-outlet>
  </router-outlet>
</div> //app.component.ts
import { Component } from '@angular/core'; import {NavigationEnd, Router} from "@angular/router";
import { routeAnimation1} from "./animation/trigger";
@Component({ selector: 'app-root', templateUrl:
'./app.component.html', styleUrls: ['./app.component.css'],
animations: [routeAnimation1] })
export class AppComponent {
routerState:boolean = true;
routerStateCode:string = 'active';
constructor(private router:Router)
{ this.router.events.subscribe(event => {
if (event instanceof NavigationEnd) { // 每次路由跳转改变状态
console.log(NavigationEnd,event) this.routerState = !this.routerState;
this.routerStateCode = this.routerState ? 'active' : 'inactive'; } }); } }

有问题,欢迎留言。。。

angular2中的路由转场动效的更多相关文章

  1. Vue-admin工作整理(七):路由的切换动效

    思路就是通过 transition-group 这个组件来对多组件进行控制,效果是通过样式来写,transition-group要有指定的key值,样式中通过name来命名类的名字 <templ ...

  2. angular2-4 之动效-animation

    提示:   angular2 时animation代码在核心模块里面(@angular/core里面);到了angular4.0时animation从核心模块中提取出来作为一个单独的模块, 这样可以在 ...

  3. 动效解析工厂:Mask 动画

    转载自:http://www.cocoachina.com/ios/20160214/15250.html 前言:很多动效都是多种动画的组合,有时候你可能只是需要其中某个动画,但面对庞杂的代码库或是教 ...

  4. 百度MUX:APP动效之美需内外兼修

    移动互联网时代已经到来.APP已如天空的繁星.数也数不清.随着手机硬件的不断升级,实现炫酷且流畅的动效不再是遥远的梦想.假设你是APP达人,喜欢试用各种APP,你肯定会发现越来越多的APP開始动效化. ...

  5. iOS 停止不必要的UI动效设计

    http://www.cocoachina.com/design/20151124/14400.html 前言:这篇短文将会探讨UI设计中动画的过度使用,并将其与早期的视觉设计进行对比,提出一些对于有 ...

  6. 前端必须收藏的CSS3动效库!!!

    现在的网站和App的设计中越来越重视用户体验,而优秀的动效则能使你的应用更具交互性,从而吸引更多用户的使用. 如果你对CSS3中定义动效还不熟练,或希望采用更加简单直接的方式在你的应用中引入动效的话, ...

  7. 【总结】前端必须收藏的CSS3动效库!!!

    现在的网站和App的设计中越来越重视用户体验,而优秀的动效则能使你的应用更具交互性,从而吸引更多用户的使用. 如果你对CSS3中定义动效还不熟练,或希望采用更加简单直接的方式在你的应用中引入动效的话, ...

  8. 巧用 -webkit-box-reflect 倒影实现各类动效

    在很久之前的一篇文章,有讲到 -webkit-box-reflect 这个属性 -- 从倒影说起,谈谈 CSS 继承 inherit -webkit-box-reflect 是一个非常有意思的属性,它 ...

  9. Google I/O 官方应用中的动效设计

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/jILRvRTrc/article/details/82881743 作者:Nick Butcher, ...

随机推荐

  1. IIS7 Microsoft.Web.Administration 创建Application问题

    在使用DirectoryEntry操作IIS时,可以设置很多属性.但使用Microsoft.Web.Administration中的一些类时,不知道在哪设置.例如:AccessScript,Acces ...

  2. java生成多位随机数方法

    Math.random()方法可以令系统随机选取大于等于0.0且小于1.0的伪随机double值 利用函数Math.random()即可生成若干位随机数 以下是生成十位随机数代码: public st ...

  3. jquery插件开发快速入门

    1.添加jQuery对象方法添加jQuery对象方法:jQuery.prototype.myMethod. 在jQuery源码中有一句:jQuery.fn = jQuery.prototype,也就是 ...

  4. 8种主要排序算法的C#实现 (二)

    归并排序 归并排序也是采用“分而治之”的方式.刚发现分治法是一种算法范式,我还一直以为是一种需要意会的思想呢. 不好意思了,孤陋寡闻了,哈哈! 原理:将两个有序的数列,通过比较,合并为一个有序数列.  ...

  5. td中不包含汉字的字符串不换行,包含汉字的能换行的问题原因及解决方法

    今天项目中遇到一个问题,一长串的字符串如:003403FF0014E54016030CC655BC3242,但是如:中国河北省石家庄市裕华区槐安路雅清街交口 这样的就可以换行. 原因是:英文字母之间如 ...

  6. Java并发编程之CountDownLatch的用法

    一.含义 CountDownLatch类位于java.util.concurrent包下,利用它可以实现类似计数器的功能.CountDownLatch是一个同步的辅助类,它可以允许一个或多个线程等待, ...

  7. 金融即服务(FaaS),将开启场景化金融新格局

    转自: https://www.iyiou.com/p/28494/fs/1 [ 亿欧导读 ] 金融即服务揭示了场景金融的实现路径,通过双向连接做一个开放的系统,按需给客户提供金融服务. 本文系作者在 ...

  8. javascript中常用函数汇总

    js中函数很多,在实际项目开发中,函数的应用可以很大程度上简化我们的代码,所以在此记下开发中js中常用的函数,增强记忆. 1.isNaN(X):函数用于检查其参数是否是非数字值. 如果 x 是特殊的非 ...

  9. slf4j和log4j、logback

    现在主流java项目一般使用slf4j+log4j的日志方案,最近抽点时间扫了一下slf4j.log4j.logback的官方文档,做个笔记.这篇比较不打算描述具体的配置方法,因为官方文档已经讲得很清 ...

  10. linux系统调用是通过软中断实现的吗

    软中断是利用硬件中断的概念,用软件方式进行模拟,实现宏观上的异步执行效果.很多情况下,软中断和信号有些类似,同时,软中断又是和硬中断相对应的,硬中断是外部设备对CPU的中断,软中断通常是硬中断服务程序 ...