How to call angular function when click p-dialog c

2019-07-10 05:24发布

How to call angular function when click p-dialog close(X) button?

I have searched and just tried this (onHide)="cancel()" . But it's not working. Kindly share your solutions.

I know we can use a close/cancel button to hide the popup. But in my scenario I want to call an event when clicking the (X) button click.

4条回答
ゆ 、 Hurt°
2楼-- · 2019-07-10 05:46

Actually (onHide)="cancel()" works fine according to this Plunkr.

查看更多
叛逆
3楼-- · 2019-07-10 05:46

A workaround is to use a boolean to display the p-dialog with

   [(visible)]="myBoolean"

You set that boolean to true when you want to display the p-dialog Then use the (click) event. For instance

    (click)="doSomething($event)".

In your ts do

    doSomething(event) {
        // If we are clicking the close button and not something else
        if (event.target.className === "fa fa-fw fa-close") {
            myBoolean = false;
        }
    }
查看更多
小情绪 Triste *
4楼-- · 2019-07-10 05:59

You should to use two events follow:

onBeforeHide: EventEmitter<any>;
onAfterHide: EventEmitter<any>;

use in html as

(onBeforeHide)="onBeforeHide()"
(onAfterHide)="onAfterHide()"

Refer: https://github.com/primefaces/primeng/issues/956

查看更多
虎瘦雄心在
5楼-- · 2019-07-10 06:11

Try: (click)="cancel()" instead.

I had the same error but I solved it by using the click method. Grettings :)

查看更多
登录 后发表回答