2011-01-11 17 views

Antwort

7

auf diese Weise:

// 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 ](); 
    } 
} 

Was hier los ist wie folgt :

Wenn trigger heißt jQuery überprüft, ob das Ereignis global ausgelöst wird ($.trigger("event_name");).

Wenn es nicht global ausgelöst wird, und Ausbreitungs wurde und das betreffende Element Element einen Elternteil nicht gestoppt (!event.isPropagationStopped() && parent) jQuery dann ruft das Triggerereignis manuell auf dem Mutterelement.

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

Es ist ein bisschen mehr los - siehe event.js in dem jQuery-Quellcode.

1

Schauen Sie sich die tutorials

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

Kasse Auch diese SO question

+5

Ich denke, er wollte nicht eine API-Erklärung, sondern eine technische Erklärung, wie sie tatsächlich funktionieren. – ThiefMaster

+0

@ThiefMaster Wenn das der Fall ist, ist der beste Weg zu lernen, die Quelle zu sehen :) http://james.padolsey.com/jquery/ –

Verwandte Themen