`
wxzauh
  • 浏览: 18310 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

handler与listener的区别

阅读更多
ExtJS里handler和listener都是用来对用户的某些输入进行处理的,有必要区分一下各自都是怎么用的。



Handler

handler与Action相关联,一个Action可以有多个Component引用;

Action是一个可被共享的对象,有五个主要的属性:text, handler, iconCls, disabled, hidden

component的构建方式比较有意思:

new Ext.Button(action)

是Button接收一个Action对象作为构造参数吗?但是查看Button的API却没有发现action属性。反而Button的构造参数是一个(Object config),也就是说,只是一个配置对象(包含各种属性),而Action的五个属性正好Button也都有,所以,可以接收一个Action来进行构造。

其他属性不考虑,看handler,Button中的handler配置项文档说明,这个handler是与click Event关联的。也就是说,click是Button这个Component的首要Event(参考Action中handler的文档),这就是Handler的运行方式:被某个组件的首要Event所触发。



Listener

上面说了handler是对首要Event的响应函数,而关于Event, Observable才是根源。

Ext.util.Observable是一切可进行事件监测之对象的父类(或者接口)。Observable只有一个配置项,那就是listeners,而一个listener是一个事件名 + 处理函数的组合,如:

"click" : function(){...}, "mouseOver" : function(){....}

Observable还提供了很多相关的处理事件的方法,比如添加事件,触发事件,移除监听器等等。



由上分析可以总结一下:

1、handler是一个特殊的listener;

2、handler是一个函数,而listener是<event , 函数>对;

3、handler与Action相关,用来让多个组件共享一个Action。而listener与Event相关,可以对Event进行方便的管理;



但是handler与普通的event + listener组合还是有一些不同,一个例子就是,如果用

Ext.util.Observable.capture(button, function(name){ if (name=="click") return false})

来事先捕获click事件,并阻止click时,如果Button的click是通过handler来响应的,则capture的return false函数无效,而如果button是定义了包含click事件的listener,则上面的capture生效。

分享到:
评论

相关推荐

    Oracle报错ORA-12516

    ### Oracle报错ORA-12516:TNS:listener could not find available handler with matching protocol stack #### 报错概述 在Oracle数据库环境中遇到ORA-12516错误时,通常意味着监听器无法找到与请求协议栈匹配的...

    JavaWeb开发技术-Listener监听器.pptx

    - **事件处理器(Event Handler)**:处理事件的逻辑,当事件发生时被调用。 - **事件监听器(Listener)**:实现了特定接口的类,注册到事件源上,用于接收并处理事件。 2. **监听器的工作流程** - **注册监听...

    Spring Boot 编写Servlet、Filter、Listener、Interceptor的方法

    Spring Boot 编写Servlet、Filter、Listener、Interceptor的方法 标题:Spring Boot 编写Servlet、Filter、Listener、Interceptor的方法 描述:Spring Boot 中如何定义过滤器、监听器和拦截器,对 Spring Boot ...

    Android View添加 Listener 实例代码

    在Android应用开发中,添加Listener是与用户交互的关键步骤,使得UI控件能够响应用户的操作。本示例主要探讨如何为Android View添加监听器,并提供了一些优化和简化代码的技巧。 首先,最常见的添加Listener的方式...

    dom-event-handler:通用DOM事件处理程序,为类方法实现EventListener接口

    $ npm install dom-event-handler 用法 const DOMEventHandler = require ( "dom-event-handler" ) class MyWSController extends SomeOtherClass { constructor ( ) { this . ws = new WebSocket ( 'ws://...

    supervisor-event-listener:Supervisor事件通知, 支持邮件, Slack, WebHook

    supervisor-event-listener Supervisor事件通知, 支持邮件, Slack, WebHook 简介 Supervisor是*nix环境下的进程管理工具, 可以把前台进程转换为守护进程, 当进程异常退出时自动重启. supervisor-event-listener监听...

    oracle10g提示oracle not available的一些个人总结

    ### Oracle 10g 提示 Oracle Not Available 的个人总结与解决方案 #### 一、问题概述 在使用 Oracle 10g 数据库时,可能会遇到“ORA-01034: ORACLE not available”和“ORA-27101: shared memory realm does not ...

    spring-kafka-listener-sample

    Spring卡夫卡听众样本如果您的侦听器引发异常,则使用ErrorHandler进行有关Spring Kafka侦听器的示例项目。技术领域Sprint Boot春天卡夫卡环境要求该示例已在本地安装中使用Apache Kafka 0.10.2进行了测试。Apache ...

    react-click-away-listener:使用React Hooks构建的Tiny React Click Away Listener

    它可以与Portal(&gt; = v2)一起使用。用法import ClickAwayListener from 'react-click-away-listener' ;const App = ( ) =&gt; {const handleClickAway = ( ) =&gt; {console . log ( 'Maybe close the popup' ) ;} ;...

    C# Socket异步通信

    Socket handler = listener.EndAccept(ar); // 创建一个状态对象,存储与连接相关的数据。 StateObject state = new StateObject(); state.WorkSocket = handler; // 开始接收数据。 handler.BeginReceive...

    php-signal-handler:该库可帮助您处理来自操作系统的信号。 例如,它将帮助您检测何时有其他进程要求您的脚本停止运行

    之后,只需调用\Sta\PhpSignalHandler\SignalHandler::attach(array(SIGTERM), $listener) ,即可: SIGTERM是PHP向我们提供的信号常量之一()。 您只会通知有关作为第一个参数传递的信号的信息,在上面

    C# .NET

    当有新的连接请求时,`listener.Accept()`会阻塞直到一个连接建立,返回一个新的Socket实例,专门用于与该客户端的通信。 为了实现异步接收数据,使用了`ManualResetEvent`来同步线程。`allDone`是一个事件标志,...

    C# 通信.pdf C#通信.pdf

    Sockethandler = listener.EndAccept(ar); ``` #### 5. 数据收发 一旦连接建立,就可以通过新创建的Socket对象来进行数据的发送和接收。发送数据使用`Send`或`BeginSend`方法,接收数据则使用`Receive`或`...

    use-event-listener:提供声明性useEventListener的自定义React Hook

    @ use-it / event-listener 提供声明性useEventListener的自定义React Hook。 这个钩子是由的博客文章启发的。 我需要一种方法来简化在自定义钩子中添加和删除事件侦听器的过程。 这导致了Dan和我之间的。 安装 $...

    HttpServer

    &lt;handler-class&gt;com.byj.control.listener.SurRefreshListener&lt;/handler-class&gt; &lt;url-pattern&gt;/refreshControl.do&lt;/url-pattern&gt; &lt;/handler&gt; &lt;handler&gt; &lt;handler-class&gt;...

    C#简单的客户端与服务端通讯

    除了Socket通信之外,还可以使用`TcpClient`和`TcpListener`类来实现客户端与服务端之间的通信。这种方式更加简便,封装了许多底层细节。 ##### 客户端代码分析 客户端的主要逻辑如下: 1. **创建TcpClient对象**...

    JAVA实现SOCKET聊天

    protected Thread listener; protected static Vector handlers = new Vector(); private boolean keepListening = true; public ChatHandler(Socket socket) { this.socket = socket; } public ...

    socket 同步服务器存储

    Socket handler = listener.Accept(); data = null; while (true) { bytes = new byte[1024]; int bytesRec = handler.Receive(bytes); data += Encoding.ASCII.GetString(bytes, 0, bytesRec); if (data....

Global site tag (gtag.js) - Google Analytics