Microsoft Asp.Net Ajax架構入門(9) 事件

來源:互聯網
上載者:User
VS 2008

本文介紹如何定義事件監聽,並訂閱事件處理方法

本文例子取自<Asp.Net Ajax in action>,並稍作修改
定義一個Collection類(集合),並定義一個事件監聽:當集合添加新的項時,觸發itemAdded事件

/**//// <reference name="MicrosoftAjax.js"/>

Type.registerNamespace("Tristan");

Tristan.Collection = function() {
    this._list = [];
    this._eventHandlers = null;
}
Tristan.Collection.prototype = {
    get_list : function() {
        return this._list;
    },
    getEventHandlers : function() {
        if(!this._eventHandlers) {
            this._eventHandlers = new Sys.EventHandlerList();
        }
        return this._eventHandlers;
    },
    add_itemAdded : function(handler) {
        this.getEventHandlers().addHandler("itemAdded", handler);
    },
    remove_itemAdded : function(handler) {
        this.getEventHandlers().removeHandler("itemAdded", handler);
    },
    _raiseEvent : function(evtName, eventArgs) {
        var handler = this.getEventHandlers().getHandler(evtName);
        if(handler) {
            handler(this, eventArgs);
        }
    },
    add : function(item) {
        Array.add(this._list, item);
        this._raiseEvent("itemAdded", this._list.length - 1);
    }
}
Tristan.Collection.registerClass("Tristan.Collection");

    釋義:
    1)用到一個Asp.Net Ajax Core Library內建的 Sys.EventHandlerList類,專門用於儲存事件訂閱。
        這個類包含幾個基本的訂閱事件和移出事件訂閱的方法:
        addHandler(String eventId, Function handler)
            訂閱事件
        removeHandler(String eventId, Function handler)
            移除事件訂閱
        getHandler(string eventId)
            獲得已訂閱的事件處理方法
    2)_raiseEvent方法標記為私人方法,專門用於調用已觸發的事件的處理方法
    3)當外部調用Collection類的Add方法時,就會觸發itemAdded事件
    4)將新添加的item的index作為參數傳出

編寫測試代碼:pageLoad = function() {
    var c = new Tristan.Collection();
    c.add_itemAdded(itemAddedHandler);
    c.add("guozhijian");
}
function itemAddedHandler(sender, eventArgs) {
    alert("an item has been added");
    alert(eventArgs);
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.