2011-01-11 16 views

Odpowiedz

7

ten sposób:

// bubbling is internal 
trigger: function(event, data, elem /*, bubbling */) { 
// Event object or event type 
var type = event.type || event, 
    bubbling = arguments[3]; 

// Handle a global trigger 
if (!elem) { 
    // Don't bubble custom events when global (to avoid too much overhead) 
    event.stopPropagation(); 

    // Only trigger if we've ever bound an event for it 
    if (jQuery.event.global[ type ]) { 
     jQuery.each(jQuery.cache, function() { 
      if (this.events && this.events[type]) { 
       jQuery.event.trigger(event, data, this.handle.elem); 
      } 
     }); 
    } 
} 

// ... snip ... 
// Trigger the event, it is assumed that "handle" is a function 
var handle = elem.nodeType ? 
    jQuery.data(elem, "handle") : 
    (jQuery.data(elem, "__events__") || {}).handle; 

if (handle) { 
    handle.apply(elem, data); 
} 

var parent = elem.parentNode || elem.ownerDocument; 
// ... snip .... 
if (!event.isPropagationStopped() && parent) { 
    jQuery.event.trigger(event, data, parent, true); 

    } else if (!event.isDefaultPrevented()) { 
    // ... snip ... 
       jQuery.event.triggered = true; 
       target[ targetType ](); 
    } 
} 

Co się tu dzieje jest następujący :

Kiedy trigger jest nazywany sprawdzaniem jQuery, aby sprawdzić, czy zdarzenie jest wyzwalane globalnie ($.trigger("event_name");).

Jeśli jest nie wyzwalane są globalnie, i propagacja nie został zatrzymany i element w kwestii ma elementu nadrzędnego (!event.isPropagationStopped() && parent jQuery), a następnie wywołuje zdarzenie wyzwalające ręcznie elementu nadrzędnego.

jQuery.event.trigger(event, data, parent, true); 

Tam jest trochę więcej dzieje - patrz event.js w kodzie źródłowym jQuery.

1

Zapoznaj się z tutorials

$(document).bind("eventType", ...); 
// This is equivalent to the plugin's $.subscribe("eventType", ...); 
$(document).trigger("eventType"); 
// equivalent to plugin's $.publish("eventType"); 

kasy Również ten SO question

+5

Myślę, że nie chciał wyjaśnienia API, ale techniczne wyjaśnienie, w jaki sposób działają. – ThiefMaster

+0

@ThiefMaster Jeśli tak jest, najlepszym sposobem nauki jest spojrzenie na źródło :) http://james.padolsey.com/jquery/ –

Powiązane problemy