169 похожих чатов

Привет всем. Есть компонент в нем кнопка и

div. При клике на кнопку div скрывается или появляется. Как сделать чтобы исчезал div если кликаем вне компонента ?

3 ответов

5 просмотров

Загугли OutsideClickDIrective github

import {Directive, ElementRef, HostListener, Input} from '@angular/core'; @Directive({ selector: '[appDropdown]', exportAs: 'appDropDown' }) export class DropdownDirective { @Input() multiple: boolean; isOpen = false; @HostListener('document:click', ['$event']) toggleOpen(event: Event) { this.isOpen = !this.multiple ? (this.elRef.nativeElement.contains(event.target) ? !this.isOpen : false) : this.elRef.nativeElement.contains(event.target); } constructor(private elRef: ElementRef) { } }

в компоненте достаточно написать @HostListener('document:click', ['$event']) handleDocumentClick(e: Event) { if (this.elRef && !this.elRef.nativeElement.contains(e.target) { this.isVisible = false; } } constructor (elRef: ElementRef) {} где isVisible - какой-то флаг, который ответственнен за отображение компонента

Похожие вопросы

Обсуждают сегодня

Сообщение* в закодированном виде. То есть, просто сделать sendMessage?text=Привет бла-бла! не получится, надо в HEX переводить, и добавлять процент, типа такого: sendMessage?t...
КТ315
21
А случайно нет ли в паскале штатной возможности передать указатель и количество туда где array of в качестве аргумента?
zamtmn
25
Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
58
Всем привет. Испытываю проблемы в работе БД, а именно огромного роста логов, такого характера: 024-05-16 18:39:07 +05 sentry sentry [unknown] 1050169 7-1 app-sentry01.corp.ru>...
Alexey
2
Если подытожить: По мнению Розыча и Хемуля и др. - предпочтительно по возможности объявлять в секции имплементации потому-что: 1) Выше скорость компиляции 2) Не замусоривается...
notme
7
Хм. А телеграм апи работают через HTTP?
The Bird of Hermes
14
Ну раз я пока тут, задам пару глупых вопросов. Зачем писать на ассемблере если компилятор довольно умный, а ассемблер много времени занимает? В каких прикладных задачах сейчас...
Максим Рябцев
20
Почему Telegram пишет, что объект media не найден, хотя на самом деле я его передаю? Делаю на urllib, без зависимостей, так надо. Вызываю метод sendMediaGroup с таким JSON: ...
Alexey S
1
В дельфе нет никакого коробочного (без установки третьих либ) способа получить CallStack с расшифровкой отладочных символов?
notme
7
Приветики всем!)) Подскажите: есть функция, которая записывает число типа Cardinal в четыре байта, хранимые в TBytes. Можете помочь мне, показав, как должна выглядеть функци...
Моринаро
5
Карта сайта