Angular文档.addEventListener监听点击外部。
创始人
2024-10-29 23:01:18
0

在Angular中,我们可以使用HostListener装饰器来监听点击事件,并检查点击事件的目标是否在组件内部。如果目标不在组件内部,即被点击的是组件外部,则执行相应的逻辑。

以下是一个示例代码:

import { Component, HostListener } from '@angular/core';

@Component({
  selector: 'app-root',
  template: `
    

Angular Event Listener

Click inside or outside of this component and check the console.

`, styles: ['div { padding: 20px; border: 1px solid black; }'] }) export class AppComponent { constructor() { } @HostListener('document:click', ['$event']) onClick(event: MouseEvent) { // 检查点击事件的目标是否在组件内部 const clickedInside = this.elementRef.nativeElement.contains(event.target); if (!clickedInside) { console.log('Clicked outside'); // 在这里执行点击外部的逻辑 } } }

在上面的示例代码中,我们使用了@HostListener('document:click', ['$event'])装饰器来监听整个文档的点击事件。然后在onClick方法中,我们使用elementRef.nativeElement.contains(event.target)来检查点击事件的目标是否在组件内部。如果目标不在组件内部,则说明点击事件发生在组件外部,我们可以在此处执行相应的逻辑。在本例中,我们只是简单地将一条消息打印到控制台。

请注意,为了使用elementRef.nativeElement.contains(event.target),我们需要在组件的构造函数中注入ElementRef

相关内容

热门资讯

透视系统!aapoker怎么选... 透视系统!aapoker怎么选牌(透视)插件(原来真的有挂)1、下载好aapoker怎么选牌辅助软件...
透视模拟器!aapoker插件... 透视模拟器!aapoker插件(透视)透视方法(确实真的有挂)1、aapoker插件ai机器人多个强...
透视辅助!aapoker透视怎... 透视辅助!aapoker透视怎么用(透视)脚本(原来真的有挂)1、实时aapoker透视怎么用开挂更...
透视规律!aapoker辅助工... 透视规律!aapoker辅助工具安全吗(透视)辅助插件工具(一直存在有挂)1、每一步都需要思考,不同...
透视脚本!aapoker俱乐部... 透视脚本!aapoker俱乐部靠谱吗(透视)透视插件(确实是真的有挂);1、aapoker俱乐部靠谱...
透视插件!aapoker ai... 透视插件!aapoker ai插件(透视)插件下载(总是真的是有挂)1、游戏颠覆性的策略玩法,独创攻...
透视存在!aapoker辅助软... 透视存在!aapoker辅助软件合法吗(透视)透视软件(其实存在有挂)1、下载好aapoker辅助软...
透视肯定!aapoker透视怎... 透视肯定!aapoker透视怎么用(透视)透视软件(真是有挂);1、进入到aapoker透视怎么用黑...
透视软件!aapoker怎么设... 透视软件!aapoker怎么设置抽水(透视)透视脚本下载(切实真的是有挂)1、完成aapoker怎么...
透视ai!aapoker脚本怎... 透视ai!aapoker脚本怎么用(透视)插件(真是真的是有挂)1、实时aapoker脚本怎么用开挂...