检查传递的元素是否被 Angular 8 类封装

我似乎找不到问题的答案或正确的角度方法来做到这一点。我知道这部分是主观的。我有一个可点击的元素。在该元素内,我还有另一个可单击的元素:


    <li (click)="route($event, d, d.isdliked)" *ngFor="let d of dList; let i = index">

        <div class="image-container" [ngStyle]="{ 'background-image': 'url(' + d.ImagePath + ')'}">

            <div class="keep-container">

                <div *ngIf="d.dliked" (click)="cantKeep()" class="liked">

                    <p>{{d.dLikes}}</p>

                </div>

                <div *ngIf="!d.dliked" (click)="keep(d, i)" class="not-liked">

                    <p>{{d.dLikes}}</p>

                </div>

            </div>

        </div>

    </li>

因此,li 元素中的第一个单击事件会将用户路由到另一个页面。另一个点击事件不会路由到任何地方。但是,如果我单击这两个内部单击事件,当我不想这样做时,我就会被路由到其他页面。


所以我尝试了这段代码来检查单击的元素是否包含“keep-container”类:


  route(element: Element, d: D, dIsLiked: boolean): void {

    if (!element.classList.contains("keep-container")) {

      this.router.navigate(['/dinfo']);

    }

  }

但这不起作用。


当然,我尝试使用element.target但没有成功。我究竟做错了什么?我会继续寻找。


主要目标:如果我单击 p 标签, <p>{{d.dLikes}}</p>我想检查它是否在类内"keep-container"


慕标5832272
浏览 111回答 1
1回答

largeQ

$event.stopPropagation()就像平常在 javascript 中一样使用<div *ngIf="d.dliked" (click)="$event.stopPropagation();cantKeep()">...</div>好吧,我喜欢在同一个 .html 中,您可以将 $event 传递给函数 cantKeep 并在 .ts 中进行 stopPropagation<div *ngIf="d.dliked" (click)="cantKeep($event)">...</div>cantKeep(event){&nbsp; event.stopPropagation();&nbsp; ...rest of actions..}
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Html5