Heim > Backend-Entwicklung > PHP-Tutorial > javascript - Was ist der Unterschied zwischen diesen beiden Methoden zum Binden benutzerdefinierter Ereignisse? Welches ist besser?

javascript - Was ist der Unterschied zwischen diesen beiden Methoden zum Binden benutzerdefinierter Ereignisse? Welches ist besser?

WBOY
Freigeben: 2016-09-15 11:30:57
Original
1363 Leute haben es durchsucht

Die erste Möglichkeit besteht darin, benutzerdefinierte Ereignisse direkt in __onfireEvents zu speichern

<code>var __onfireEvents = {};

function _bind(eventName, callback, is_one, context) {
    if (typeof eventName !== string_str || typeof callback !== function_str) {
        throw new Error('args: '+string_str+', '+function_str+'');
    }
    if (! hasOwnKey(__onfireEvents, eventName)) {
        __onfireEvents[eventName] = {};
    }
    __onfireEvents[eventName][++__cnt] = [callback, is_one, context];

    return [eventName, __cnt];
}

function on(eventName, callback, context) {
    return _bind(eventName, callback, 0, context);
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Die zweite Methode besteht darin, das benutzerdefinierte Ereignis zu speichern. Der Unterschied besteht jedoch darin, dass es an das Element gebunden ist. Gibt es hier Vorteile?

<code>$customSubMap = {};
subscribeEvent = function ( $collection, event_name, fn ) {
    $collection.on( event_name, fn );
   

    if ( ! $customSubMap[ event_name ] ) {
        $customSubMap[ event_name ] = $collection;
    }
    else {
        $customSubMap[ event_name ]
        = $customSubMap[ event_name ].add( $collection );
    }
};</code>
Nach dem Login kopieren
Nach dem Login kopieren

Antwortinhalt:

Die erste Möglichkeit besteht darin, benutzerdefinierte Ereignisse direkt in __onfireEvents zu speichern

<code>var __onfireEvents = {};

function _bind(eventName, callback, is_one, context) {
    if (typeof eventName !== string_str || typeof callback !== function_str) {
        throw new Error('args: '+string_str+', '+function_str+'');
    }
    if (! hasOwnKey(__onfireEvents, eventName)) {
        __onfireEvents[eventName] = {};
    }
    __onfireEvents[eventName][++__cnt] = [callback, is_one, context];

    return [eventName, __cnt];
}

function on(eventName, callback, context) {
    return _bind(eventName, callback, 0, context);
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

Die zweite Methode besteht darin, das benutzerdefinierte Ereignis zu speichern. Der Unterschied besteht jedoch darin, dass es an das Element gebunden ist. Gibt es hier Vorteile?

<code>$customSubMap = {};
subscribeEvent = function ( $collection, event_name, fn ) {
    $collection.on( event_name, fn );
   

    if ( ! $customSubMap[ event_name ] ) {
        $customSubMap[ event_name ] = $collection;
    }
    else {
        $customSubMap[ event_name ]
        = $customSubMap[ event_name ].add( $collection );
    }
};</code>
Nach dem Login kopieren
Nach dem Login kopieren

Es scheint, dass das zweite besser lesbar ist.

Eigentlich gibt es meiner Meinung nach keinen Unterschied zwischen den beiden, genau wie die Beziehung zwischen Produkten und Kategorien. Sie können {Produkt1:[Kategorie1, Kategorie2]} oder {Kategorie1: [Produkt1, Produkt2]} sagen

Mein persönliches Gefühl ist das zweitbeste

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage