Angular @HostListener 装饰器的使用笔记

简介: Angular @HostListener 装饰器的使用笔记

在 angular 中,通过不同的方式检测点击。 由于 click 是一个事件,因此在组件内部它是通过简单的事件绑定来检测的。 通过事件绑定在组件内进行检测的简单单击如下所示:

@Component({
selector: "geeks",
template: `
<h1 (click)="clicked()">{{ some_text }}</h1>
`
})
export class GeeksComponent {
constructor() {}
some_text = "Click Here";
clicked() {
  this.some_text = "Event Triggered";
}
}

为了继续检测组件外的点击,@HostListener 装饰器在 angular 中使用。 它是一个装饰器,它声明一个要侦听的 DOM 事件,并提供一个带有处理程序方法的链接,以便在该事件发生时运行。


方法:这里的方法是使用@HostListener 装饰器。 在 angular 中,它是一个装饰器,有助于捕获 DOM 内发生的任何类型的事件,并为开发人员提供基于该事件执行任何操作的灵活性。 在这里,在简单的点击事件上,处理程序将把点击事件引用到组件上,对于整个 DOM 的点击,它将使用 document:click 捕获。


使用 HostListener 的语法如下:

@HostListener(events, args)
handler_name(args){
  // Do something
}

HostListener的语法有三点需要注意:


(1) eventName:顾名思义,它接收 DOM 中需要监听的事件的名称。

(2) args:这些是在事件发生时传递给处理程序方法的参数集。 它以列表格式输入。

(3) handlen_name:这里是事件触发时调用的方法定义。 它由 HostListener 自动调用。


示例:在组件内绑定单击


为了在组件内绑定单击事件,将 hostListener 的 eventName 维护成值 “click”。 在这种情况下,上面的

代码将写为:

@Component({
selector: "geeks",
template: `
  <h1>{{ some_text }}</h1>
`
})
export class GeeksComponent {
constructor() {}
some_text = "Click Here";
@HostListener("click")
clicked() {
  this.some_text = "Event Triggered";
}
}

点击 Click here,屏幕将显示:

Event Triggered:

Bind with click outside component

为了检测组件外的点击,需要查看另一个事件。 这里的 click 将不起作用,因为它检测到组件内的点击。 这里的关键是在DOM中寻找点击,而不仅仅是组件,因此document:click将是正确的选择,同时我们需要过滤掉组件内的事件, 这是由布尔变量 inside 完成的。

所以在下面给出的代码中,将添加另一个组件作为外部上下文,但是单击它会导致当前组件上的单击事件。

@Component({
selector: "another",
template: `
  <div style="border-style: solid;margin:5px;">
  <h1>Outside Component</h1>
  <h2>Click here for outer component trigger</h2>
  </div>
  <geeks></geeks>
`
})
export class AnotherComponent {
constructor() {}
}
@Component({
selector: "geeks",
template: `
  <div style="border-style:solid;margin:5px;">
  <h1>Inner Component</h1>
  <h2>{{ some_text }}</h2>
  </div>
`
})
export class GeeksComponent {
constructor() {}
some_text = "Click Here";
inside = false;
@HostListener("click")
clicked() {
  this.inside = true;
}
@HostListener("document:click")
clickedOut() {
  this.some_text = this.inside
  ? "Event Triggered"
  : "Event Triggered Outside Component";
  this.inside = false;
}
}

在这个例子中,如果点击文本Outside Component,那么显示的文本将是Event Triggered Outside Component。 这显示了如何在 GeeksComponent 内捕获组件外部的点击。

相关文章
|
2月前
|
Java Spring
🔥JSF 与 Spring 强强联手:打造高效、灵活的 Web 应用新标杆!💪 你还不知道吗?
【8月更文挑战第31天】JavaServer Faces(JSF)与 Spring 框架是常用的 Java Web 技术。本文介绍如何整合两者,发挥各自优势,构建高效灵活的 Web 应用。首先通过 `web.xml` 和 `ContextLoaderListener` 配置 Spring 上下文,在 `applicationContext.xml` 定义 Bean。接着使用 `@Autowired` 将 Spring 管理的 Bean 注入到 JSF 管理的 Bean 中。
37 0
|
12月前
|
JavaScript
关于 Angular 的 HostBinding 装饰器
关于 Angular 的 HostBinding 装饰器
如何使用Angular的@Input()装饰器
如何使用Angular的@Input()装饰器
149 0
如何使用Angular的@Input()装饰器
Angular6在自定义指令中使用@HostBingDing() 和@HostListener()
emmm,,,最近在为项目的第二阶段铺路,偶然看到directive,想想看因为项目已经高度集成了第三方组件,所以对于自定义指令方面的经验自己实在知之甚少,后面经过阅读相关资料,总结一篇关于在自定义指令中使用@HostBingDing() 和@HostListenner()。
1904 0
|
前端开发 JavaScript 索引
angular中的装饰器 详解
Angular中的装饰器是一个函数,它将元数据添加到类、类成员(属性、方法)和函数参数。用法:要想应用装饰器,把它放到被装饰对象的上面或左边。 Angular 使用自己的一套装饰器来实现应用程序各部件之间的相互操作 这个地方是前面几个模块模块、指令、组件、依赖注入等从装饰器这个侧面的整理 你需要做的: 1.搞清楚理解TypeScript的装饰器的原理 2.搞清楚这里面每一个装饰器的作用,解决的什么问题,应用场景类装饰器****** Angular 有很多装饰器,它们负责把元数据附加到类上,以了解那些类的设计意图以及它们应如何工作。
1247 0
|
前端开发 JavaScript
angular2.0装饰器祥解
什么是装饰器? 装饰器是一个函数,它将元数据添加到类、类成员(属性、方法)和函数参数。 装饰器是一个 JavaScript 的语言特性,装饰器在 TypeScript 里已经实现,并被推荐到了ES2016(也就是ES7)。
1046 0
|
22天前
|
缓存 JavaScript 前端开发
Angular 应用打包和部署
Angular 应用打包和部署
55 1
|
2月前
|
应用服务中间件 Java Maven
掌控视图的力量!深入解析 JSF 视图管理,揭秘视图生命周期的秘密,让你的应用更高效!
【8月更文挑战第31天】JavaServer Faces (JSF) 是一种强大的框架,用于管理 Web 应用程序的视图。本文通过具体案例介绍 JSF 视图管理的基础知识,包括创建、管理和销毁视图的过程。首先,在 Eclipse 中创建一个新 JSF 项目,并配置 Maven 依赖。接着,在 `WEB-INF` 目录下配置 `web.xml` 文件,设置 JSF servlet。
37 0
|
2月前
|
开发者 Java 开发框架
JSF与EJB,打造企业级应用的神器!让你的Web应用更加稳定、高效!
【8月更文挑战第31天】在现代企业级应用开发中,JSF(JavaServer Faces)与EJB(Enterprise JavaBeans)是两大核心技术。JSF作为一款基于Java的Web应用框架,以其丰富的UI组件和表单处理功能著称;EJB则专注于提供分布式事务处理及远程调用等企业级服务。两者的结合为企业应用带来了高效便捷的开发模式。下文将通过一个简单的示例展示如何利用JSF进行用户信息的输入与保存,并借助EJB实现相关业务逻辑。尽管这一组合具有明显优势,但在实际应用中还需考虑其局限性并作出合理选择。
43 0
|
2月前
|
开发者 安全 SQL
JSF安全卫士:打造铜墙铁壁,抵御Web攻击的钢铁防线!
【8月更文挑战第31天】在构建Web应用时,安全性至关重要。JavaServer Faces (JSF)作为流行的Java Web框架,需防范如XSS、CSRF及SQL注入等攻击。本文详细介绍了如何在JSF应用中实施安全措施,包括严格验证用户输入、使用安全编码实践、实施内容安全策略(CSP)及使用CSRF tokens等。通过示例代码和最佳实践,帮助开发者构建更安全的应用,保护用户数据和系统资源。
39 0
下一篇
无影云桌面