ExtJs 学习之开篇(二) Observable 给类添加监听

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.οnclick=function(){alert("handler1")};
    e.οnclick=function(){alert("handler2")};
    /**
     * 在ExtJs中,绑定的两次事件都会执行,不会发生第二次绑定覆盖掉第一次事件
     */
    var te=Ext.get('walk');
    te.on('click',function(){
        alert("handler1");
    });
    te.on('click',function(){
        alert("handler2");
    });
    
});

 

转载于:https://www.cnblogs.com/pwpw1218/p/3429579.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值