"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > Aquí hay algunos títulos posibles: 1. ¿Cómo hacer que las transiciones CSS funcionen con `ngIf` en Angular 2? 2. ¿Por qué `ngIf` interrumpe mis transiciones CSS en Angular 2? 3. Angular 2: Combinando animaciones `ngIf` y CSS para una trans suave

Aquí hay algunos títulos posibles: 1. ¿Cómo hacer que las transiciones CSS funcionen con `ngIf` en Angular 2? 2. ¿Por qué `ngIf` interrumpe mis transiciones CSS en Angular 2? 3. Angular 2: Combinando animaciones `ngIf` y CSS para una trans suave

Publicado el 2024-11-08
Navegar:545

以下是几种可能的标题:

1. How to Make CSS Transitions Work with `ngIf` in Angular 2? 
2. Why Does `ngIf` Break My CSS Transitions in Angular 2?
3. Angular 2: Combining `ngIf` and CSS Animations for Smooth Transitions
4. Troubleshooting CSS Transitions and `ngIf` in

transiciones/animaciones ngIf y CSS en Angular 2

¿Cómo deslizar un div desde la derecha usando CSS en Angular 2?

Notes

.transition{
  -webkit-transition: opacity 1000ms ease-in-out,margin-left 500ms ease-in-out;
  -moz-transition: opacity 1000ms ease-in-out,margin-left 500ms ease-in-out;
  -ms-transition: opacity 1000ms ease-in-out,margin-left 500ms ease-in-out ;
  -o-transition: opacity 1000ms ease-in-out,margin-left 500ms ease-in-out;
  transition: opacity 1000ms ease-in-out,margin-left 500ms ease-in-out;
  margin-left: 1500px;
  width: 200px;
  opacity: 0;
}

.transition{
  opacity: 100;
  margin-left: 0;
}

Este código funciona bien si solo usas [ngClass] para cambiar de clase y aprovechar la opacidad. Pero no quiero que ese elemento se represente desde el principio, así que primero lo "oculto" con ngIf, pero luego la transición no funcionará.

Actualización 4.1.0

usa la API de animación de transición, ya no es necesario usar [oculto] o [*ngSi está oculto].

Actualización 2.1.0

Ver animación en angular.io

import { trigger, style, animate, transition } from '@angular/animations';

@Component({
  selector: 'my-app',
  animations: [
    trigger(
      'enterAnimation', [
        transition(':enter', [
          style({transform: 'translateX(100%)', opacity: 0}),
          animate('500ms', style({transform: 'translateX(0)', opacity: 1}))
        ]),
        transition(':leave', [
          style({transform: 'translateX(0)', opacity: 1}),
          animate('500ms', style({transform: 'translateX(100%)', opacity: 0}))
        ])
      ]
    )
  ],
  template: `
    

    
xxx
` }) export class App { show:boolean = false; }

Respuesta original

Cuando la expresión se vuelve falsa, *ngIf eliminará el elemento del DOM. Un elemento que no existe no se puede realizar la transición.

se puede reemplazar por el atributo oculto:

Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3