2

Server Sent Event 接続を一時停止するにはどうすればよいですか? それとも、SSE を閉じてから再度開き、すべてのイベント ハンドラーを再度割り当てる必要がありますか?

たとえば、私はやりたいと思います(これはすべて理論上のものであり、一時停止/再開関数の名前はわかりません):

var source = new EventSource(url);

source.addEventListener("something", somefunction, false);
source.addEventListener("somethingElse", somefunction2, false);

//...some code

source.pause();


//...some code

source.restart();
4

1 に答える 1

3

はい、それは技術的に発生する必要があることですが、それを抽象化することができます。注:これはあなたがした後にのみ接続します.connect()

function EventSource2(url) {
    this.url = url;
    this.es = null;
    this.listeners = {};
}

EventSource2.prototype = {
    constructor: EventSource2,


    connect: function() {
        this.es = new EventSource(this.url);
        this.bindEvents();
    },

    disconnect: function() {
        this.es.close();
        this.es = null;
    },

    bindEvents: function() {
        for ( var type in this.listeners ) {
            var evs = this.listeners[type];
            for( var i = 0; i < evs.length; ++i ) {
                this.es.addEventlistener( type, evs[i], false );
            }
        }
    },

    addEventListener: function( type, fn ) {
        if( !this.listeners[type] ) {
            this.listeners[type] = [];
        }

        this.listeners[type].push( fn );
        if( this.es ) {
            this.bindEvents();
        }
    }
}

使用法:

var source = new EventSource2(url);

source.addEventListener("something", somefunction, false);
source.addEventListener("somethingElse", somefunction2, false);

source.connect();

source.disconnect();

source.connect();
于 2012-07-09T15:33:33.420 に答える