html:代码

DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<link type="text/css" rel="stylesheet"  href="../../extjs-4.1.1/resources/css/ext-all.css"  />
<script type="text/javascript" src="../../extjs-4.1.1/bootstrap.js"></script>
<script type="text/javascript" src="../../extjs-4.1.1/locale/ext-lang-zh_CN.js"></script>
<script type="text/javascript" src="event.js"></script>
</head>
<body>
    <button id="walk">walk</button>
    <button id="eat">eat</button>
    <button id="sleep">sleep</button>
</body>
</html>

event.js:代码

Ext.onReady(function(){
    /**
     * Ext 中事件分为自定义事件和浏览器事件
     */
    /**
     * 第一步定义Person,注册监听事件
     */
    
    Ext.define("Person",{
        extend:'Ext.util.Observable',//添加监听必须继承Observable
        constructor:function(config){
            this.name=config.name;
            this.addEvents({
                'walk':true,//监听名,是否启
                'eat':true,
                'sleep':true
            });
            this.listeners=config.listeners;
             Person.superclass.constructor.call(this, config);
        }
    });
    
    /**
     * 给person 添加事件监听器
     */
    
    var person=new Person({
        name:'Longo',
        listeners:{
            walk:function(){
                Ext.Msg.alert("event",person.name+" 再走啊走啊");
            },
            eat:function(breakfast,lunch,supper){
                Ext.Msg.alert("event",person.name+" 要吃"+breakfast+","+lunch+" 和 "+supper);
            },
            sleep:function(time){
                Ext.Msg.alert("event",person.name+" 从 "+time+" 开始睡觉");
            }
        }
    });
    
    
    Ext.get('walk').on('click',function(){
        person.fireEvent('walk');
    });
    Ext.get('eat').on('click',function(){
        person.fireEvent('eat','早餐','中餐','晚餐');
    });
    Ext.get('sleep').on('click',function(){
        person.fireEvent('sleep',new Date());
    });
});

浏览器事件

Ext.onReady(function(){
    /**
     * 元素的onclick事件,第一个绑定的事件会被第二个事件覆盖,
     * 再Extjs你不用再担心这种事件
     */
    
    var e=document.getElementById("walk");
    e.onclick=function(){alert("handler1")};
    e.onclick=function(){alert("handler2")};
    /**
     * 在ExtJs中,绑定的两次事件都会执行,不会发生第二次绑定覆盖掉第一次事件
     */
    var te=Ext.get('walk');
    te.on('click',function(){
        alert("handler1");
    });
    te.on('click',function(){
        alert("handler2");
    });
    
});

ExtJs 学习之开篇(二) Observable 给类添加监听的更多相关文章

  1. extjs 学习笔记(二)

    EXTJS实用开发指南 1. 要使用ExtJS 框架的页面中一般包括下面几句: <link rel="stylesheet" type="text/css" ...

  2. JavaScript学习总结(十二)——JavaScript编写类

    在工作中经常用到JavaScript,今天总结一下JavaScript编写类的几种写法以及这几种写法的优缺点,关于JavaScript编写类的方式,在网上看到很多,而且每个人的写法都不太一样,经常看到 ...

  3. android菜鸟学习笔记23----ContentProvider(三)利用内置ContentProvider监听短信及查看联系人

    要使用一个ContentProvider,必须要知道的是它所能匹配的Uri及其数据存储的表的结构. 首先想办法找到访问短信及联系人数据的ContentProvider能接受的Uri: 到github上 ...

  4. java web hello world(二)基于Servlet理解监听

    java web最开始实现是通过Servlet实现,这里就来实现下,最原始的监听是如何实现的. 第一步,创建一个基本的web项目 ,参见(java web hello world(一)) 第二步,we ...

  5. Extjs学习笔记--(二)

    1.配置实用Extjs <link href="Extjs/resources/css/ext-all.css" rel="stylesheet" /&g ...

  6. [转]ExtJS学习笔记(二):handler与listener的区别

    原文地址:http://blog.csdn.net/smilingleo/article/details/3733177 ExtJS里handler和listener都是用来对用户的某些输入进行处理的 ...

  7. ExtJs 学习之开篇(-)之define

    Ext.onReady(function(){    /**     * test1,声明一个类,定义类中的方法     */ Ext.define("demo.Demo",{   ...

  8. 【C#】第3章学习要点(二)自定义类和结构

    分类:C#.VS2015 创建日期:2016-06-19 使用教材:(十二五国家级规划教材)<C#程序设计及应用教程>(第3版) 一.要点概述 别人提供的类都是为了简化你的工作量用的,可是 ...

  9. Cocos2d-x学习笔记(二)AppDelegate类详解

    由源代码,可得到如下的类继承关系: 1. 在方法applicationDidFinishLaunching中,首先会调用CCDirector* pDirector = CCDirector::shar ...

随机推荐

  1. SparkStreaming运行出现 java.lang.NoClassDefFoundError: org/apache/htrace/Trace 错误

    1.简介 最近在摸索利用sparkstreaming从kafka中准实时的读取数据,并将在读取的过程中,可以做一个简单的分析,最后将分析结果写入hbase中. 2.出现的问题 (1)将从kafka中读 ...

  2. JS第二天简单总结

    布尔型变量:true,flase 广泛用于真假的逻辑判断 对象:分类,对象是由一些彼此相关的属性和方法集合在一起而构成的一个数据实体: 例如,var today = new Date();中,Date ...

  3. 字符串strcpy

    strcpy函数的表达方式: //把一个char组成的字符串循环右移n个,如:“abcdefghi",n=2,移动后"hiabcdefgh" #include <i ...

  4. 常用类String的方法

    String str="hello"; 1.与数组相关的方法 System.out.println(str.length()); System.out.println(str.ch ...

  5. fork函数创建新进程过程分析

    gdb调试执行流程,首先设置断点b sys_clone,当在shell下输入fork命令后,系统执行至断点,接下来按步执行: 判断是否被跟踪 判断是否被创建为轻量级进程(vfork) 判断父进程是否被 ...

  6. Appium常用的API函数

    在学习应用一个框架之前,应该了解一下这个框架的整体结构或是相应的API函数.这篇文章还不错:http://blog.sina.com.cn/s/blog_68f262210102vzf9.html,就 ...

  7. 解决Tomcat7“At least one JAR was scanned for TLDs yet contained no TLDs”问题

    解决Tomcat7“At least one JAR was scanned for TLDs yet contained no TLDs”问题 2013-12-05 21:58:00|  分类: t ...

  8. iOS—Mask属性的使用

    Mask属性介绍 Mask平时用的最多的是masksToBounds 吧. 其实除此以外Mask使用场景很多,看完之后你会发现好真是好用的不要不要的... 先来了解下Mask属性到底是什么? Mask ...

  9. js 文本框只能输入数字

    <input type="text" value="" style="ime-mode:Disabled"  onkeyup=&quo ...

  10. Python::re 模块 -- 在Python中使用正则表达式

    前言 这篇文章,并不是对正则表达式的介绍,而是对Python中如何结合re模块使用正则表达式的介绍.文章的侧重点是如何使用re模块在Python语言中使用正则表达式,对于Python表达式的语法和详细 ...