133 votes

Détecter le clic en dehors du composant angulaire

Comment détecter les clics hors d' un composant dans Angular?

223voto

AMagyar Points 1251
 import { Component, ElementRef, HostListener, Input } from '@angular/core';

@Component({
  selector: 'selector',
  template: `
    <div>
      {{text}}
    </div>
  `
})
export class AnotherComponent {
  public text: String;

  @HostListener('document:click', ['$event'])
  clickout(event) {
    if(this.eRef.nativeElement.contains(event.target)) {
      this.text = "clicked inside";
    } else {
      this.text = "clicked outside";
    }
  }

  constructor(private eRef: ElementRef) {
    this.text = 'no clicks yet';
  }
}
 

Exemple de travail Plunker - cliquez ici

64voto

J. Frankenstein Points 340

Une alternative à AMagyar de réponse. Cette version fonctionne lorsque vous cliquez sur l'élément qui est supprimé à partir du DOM avec un ngIf.

http://plnkr.co/edit/4mrn4GjM95uvSbQtxrAS?p=preview

  private wasInside = false;
  
  @HostListener('click')
  clickInside() {
    this.text = "clicked inside";
    this.wasInside = true;
  }
  
  @HostListener('document:click')
  clickout() {
    if (!this.wasInside) {
      this.text = "clicked outside";
    }
    this.wasInside = false;
  }

2voto

James Bond Points 11

Vous pouvez utiliser la méthode useclickOutside () à partir du paquet https://www.npmjs.com/package/ng-click-outside

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X