- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在构建一个类似于 http://rectangleworld.com/demos/SimpleDragging/SimpleDragging 的简单 Canvas 拖放应用程序.对于鼠标事件监听器,我使用了@HoSTListener,因为对我来说它具有更简单的语法并且可以正常工作。还有另一种方法可以通过 Renderer.listen 实现。但我不能决定在 hoSTListener 上使用它。谁能解释一下 @HostListener
和 Renderer.listen
哪个更好?
最佳答案
我的回答可能不是最好的,但这是我得到的。
当涉及到 Renderer.listen()
时,您需要传递要检测的 Element
,然后是 Event
监听(click
、keydown
、keyup
等),最后是 回调函数
在代码中,这是 listen()
函数 (*) 中发生的事情:
listen(renderElement: any, name: string, callback: Function): Function {
return this._rootRenderer.eventManager.addEventListener(renderElement, name, decoratePreventDefault(callback));
}
所以现在的问题只是指定 Element
(简单),但人们通常使用 elementRef.nativeElement
,这有安全风险至 Angular Documentation ,所以在使用之前一定要确定!另一个问题(不会真的)是 Renderer
类是实验性的(Check its Documentation),我遇到了 setText()
的问题,它曾经在 RC 中工作但是现在它不是.. 所以是的,在使用它们之前测试 Renderer
功能。 aaaaaa,完成后您需要手动取消绑定(bind)事件!,Check this answer for more .
但我会密切关注 Renderer
状态,因为它的主要目的是使用一个代码库在任何环境(Web、节点、移动设备等)上渲染元素,所以是的让我们希望它在未来变得稳定。
HostListener
是一个很棒的装饰器,展示了 Angular2 与 TypeScript 的协同工作,你只需要设置事件和传递给回调函数(它下面的函数)的值,通常人们只需传递 [$event]
这样您就可以更好地控制函数内部的验证,是的,您不需要设置 Element
因为它会监听 document
所以它正在对事件执行 delegation
并且您不访问 DOM
并且您的应用程序将受到保护。此外,您不需要取消绑定(bind)事件,Angular 会为您完成。
Check this article for a working example
希望我的回答对您有所帮助,请记住 Angular 仍在不断发展,所以有些事情可能会发生变化。
引用资料:
*: Hacking Angular2: Binding Multiple DOM Events by Sean T. Larkin
关于angular - @HostListener 和 Renderer.listen 哪个更好?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40610226/
我正在尝试捕捉评论状态事件,例如有人正在关闭它。并在从插件中获得任何生命迹象之后。向日志文件(从任何日志级别)或 STDOUT 发送一行。atlassian-plugins.xml 看起来像这样:
我在跑; sass --watch --style compressed --sourcemap css/sass:css 我得到了; NameError: uninitialized constan
您好,我正在创建一个 android 应用程序作为 ejabbered 服务器的 XMPP 客户端。 但我真的很困惑,因为我看到我可以将消息作为数据包或消息发送,我也可以使用 PacketListen
我有一个 imageview - 它的属性 -focusable 和 focusableintouchmode 都设置为 true 我已经在我的 Activity 中实现了 onFocus
我有一个查询来查找指定条形码的文档 ID: Future findBarcode() async { String searchBarcode = await BarcodeScanner.sca
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 5 年前。 Improve
这可能是一个非常基本的问题,但我就是不明白。使用 Express.js 创建应用和启动应用监听 1234 端口有什么区别,例如: var express = require('express'); v
所以我想知道什么是更好看的解决方案/有什么区别以及在决定制作多个监听器(1 个监听器用于 1 个按钮)还是仅 1 个 ActionListener 用于 GUI 中的所有按钮(大约 10 个按钮),并
我目前正在尝试制作一个聊天室服务器。我正在努力做到这一点,以便我可以同时监听新请求的连接和监听从已建立的连接发送的消息。 我可以用它来监听请求的连接: def reqlisten(): glo
有没有办法在事件监听器方法中访问类上下文并有可能删除监听器? 示例 1: import {EventEmitter} from "events"; export default class Event
应用程序在本地主机上工作正常。但是当它连接到服务器时出现错误。 我通过端口 22 连接服务器 这是错误 Error: listen EADDRNOTAVAIL Error: listen EADDRN
我有类似的东西: $scope.$on(config.SOME_CONSTANT, ()=> { activate(); // plus a bunch of instantiatio
我的 HTML 页面上有以下 Controller : ... ... 此子 Controller 映射到以下 c
我的 HTML 页面上有以下 Controller : ... ... 此子 Controller 映射到以下 c
我构建了一个自定义属性并将其添加到可观察列表中。但是,如果属性内容发生更改,则不会调用任何监听器。以下代码片段向您展示了“建筑”: public static final class TestObje
这里我不明白这两种方法的基本区别是什么。 var events = require('events'); var eventEmitter = new events.EventEmitter(); v
我正在尝试使用 grunt-express 设置 Grunt 来启动我的 Express 服务器。读完docs后和 this SO question ,我还是想不通。我已经为我的 Grunt 文件尝试
如果这里问题的某些方面不清楚,我深表歉意,因为我是 Node 和 javascript 的新手。请询问更多详情 我有一个使用 socketio 连接到 firebase 的 Node 应用程序。在 h
情况 我可能没有使用传统意义上的 PHPUnit。我正在使用带有 Selenium 2 的 PHPUnit。我们有这个想法来记录 Selenium 以“重现步骤”的方式执行的操作。这意味着如果我们调用
我正在尝试学习在 struts2 中使用 session 。所以,我只想实现一个登录/注销、配置文件应用程序。我正在关注互联网上提供的基本教程。但是,它根本不起作用。请帮助我解决以下问题如何解决。 S
我是一名优秀的程序员,十分优秀!