Вход Регистрация
Файл: Main Website Files/assets/bower_components/jquery/src/event.js
Строк: 1144
<?php
define
([
    
"./core",
    
"./var/strundefined",
    
"./var/rnotwhite",
    
"./var/hasOwn",
    
"./var/slice",
    
"./event/support",
    
"./data/var/data_priv",

    
"./core/init",
    
"./data/accepts",
    
"./selector"
], function( jQuerystrundefinedrnotwhitehasOwnslicesupportdata_priv ) {

var
    
rkeyEvent = /^key/,
    
rmouseEvent = /^(?:mouse|pointer|contextmenu)|click/,
    
rfocusMorph = /^(?:focusinfocus|focusoutblur)$/,
    
rtypenamespace = /^([^.]*)(?:.(.+)|)$/;

function 
returnTrue() {
    return 
true;
}

function 
returnFalse() {
    return 
false;
}

function 
safeActiveElement() {
    try {
        return 
document.activeElement;
    } catch ( 
err ) { }
}

/*
 * Helper functions for managing events -- not part of the public interface.
 * Props to Dean Edwards' addEvent library for many of the ideas.
 */
jQuery.event = {

    global: {},

    
add: function( elemtypeshandlerdataselector ) {

        var 
handleObjIneventHandletmp,
            
eventsthandleObj,
            
specialhandlerstypenamespacesorigType,
            
elemData data_priv.getelem );

        
// Don't attach events to noData or text/comment nodes (but allow plain objects)
        
if ( !elemData ) {
            return;
        }

        
// Caller can pass in an object of custom data in lieu of the handler
        
if ( handler.handler ) {
            
handleObjIn handler;
            
handler handleObjIn.handler;
            
selector handleObjIn.selector;
        }

        
// Make sure that the handler has a unique ID, used to find/remove it later
        
if ( !handler.guid ) {
            
handler.guid jQuery.guid++;
        }

        
// Init the element's event structure and main handler, if this is the first
        
if ( !(events elemData.events) ) {
            
events elemData.events = {};
        }
        if ( !(
eventHandle elemData.handle) ) {
            
eventHandle elemData.handle = function( ) {
                
// Discard the second event of a jQuery.event.trigger() and
                // when an event is called after a page has unloaded
                
return typeof jQuery !== strundefined && jQuery.event.triggered !== e.type ?
                    
jQuery.event.dispatch.applyelemarguments ) : undefined;
            };
        }

        
// Handle multiple events separated by a space
        
types = ( types || "" ).matchrnotwhite ) || [ "" ];
        
types.length;
        while ( 
t-- ) {
            
tmp rtypenamespace.exectypes[t] ) || [];
            
type origType tmp[1];
            
namespaces = ( tmp[2] || "" ).split"." ).sort();

            
// There *must* be a type, no attaching namespace-only handlers
            
if ( !type ) {
                continue;
            }

            
// If event changes its type, use the special event handlers for the changed type
            
special jQuery.event.specialtype ] || {};

            
// If selector defined, determine special event api type, otherwise given type
            
type = ( selector special.delegateType special.bindType ) || type;

            
// Update special based on newly reset type
            
special jQuery.event.specialtype ] || {};

            
// handleObj is passed to all event handlers
            
handleObj jQuery.extend({
                
typetype,
                
origTypeorigType,
                
datadata,
                
handlerhandler,
                
guidhandler.guid,
                
selectorselector,
                
needsContextselector && jQuery.expr.match.needsContext.testselector ),
                namespace: 
namespaces.join(".")
            }, 
handleObjIn );

            
// Init the event handler queue if we're the first
            
if ( !(handlers eventstype ]) ) {
                
handlers eventstype ] = [];
                
handlers.delegateCount 0;

                
// Only use addEventListener if the special events handler returns false
                
if ( !special.setup || special.setup.callelemdatanamespaceseventHandle ) === false ) {
                    if ( 
elem.addEventListener ) {
                        
elem.addEventListenertypeeventHandlefalse );
                    }
                }
            }

            if ( 
special.add ) {
                
special.add.callelemhandleObj );

                if ( !
handleObj.handler.guid ) {
                    
handleObj.handler.guid handler.guid;
                }
            }

            
// Add to the element's handler list, delegates in front
            
if ( selector ) {
                
handlers.splicehandlers.delegateCount++, 0handleObj );
            } else {
                
handlers.pushhandleObj );
            }

            
// Keep track of which events have ever been used, for event optimization
            
jQuery.event.global[ type ] = true;
        }

    },

    
// Detach an event or set of events from an element
    
remove: function( elemtypeshandlerselectormappedTypes ) {

        var 
jorigCounttmp,
            
eventsthandleObj,
            
specialhandlerstypenamespacesorigType,
            
elemData data_priv.hasDataelem ) && data_priv.getelem );

        if ( !
elemData || !(events elemData.events) ) {
            return;
        }

        
// Once for each type.namespace in types; type may be omitted
        
types = ( types || "" ).matchrnotwhite ) || [ "" ];
        
types.length;
        while ( 
t-- ) {
            
tmp rtypenamespace.exectypes[t] ) || [];
            
type origType tmp[1];
            
namespaces = ( tmp[2] || "" ).split"." ).sort();

            
// Unbind all events (on this namespace, if provided) for the element
            
if ( !type ) {
                for ( 
type in events ) {
                    
jQuery.event.removeelemtype types], handlerselectortrue );
                }
                continue;
            }

            
special jQuery.event.specialtype ] || {};
            
type = ( selector special.delegateType special.bindType ) || type;
            
handlers eventstype ] || [];
            
tmp tmp[2] && new RegExp"(^|\.)" namespaces.join("\.(?:.*\.|)") + "(\.|$)" );

            
// Remove matching events
            
origCount handlers.length;
            while ( 
j-- ) {
                
handleObj handlers];

                if ( ( 
mappedTypes || origType === handleObj.origType ) &&
                    ( !
handler || handler.guid === handleObj.guid ) &&
                    ( !
tmp || tmp.testhandleObj.namespace ) ) &&
                    ( !
selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) {
                    
handlers.splicej);

                    if ( 
handleObj.selector ) {
                        
handlers.delegateCount--;
                    }
                    if ( 
special.remove ) {
                        
special.remove.callelemhandleObj );
                    }
                }
            }

            
// Remove generic event handler if we removed something and no more handlers exist
            // (avoids potential for endless recursion during removal of special event handlers)
            
if ( origCount && !handlers.length ) {
                if ( !
special.teardown || special.teardown.callelemnamespaceselemData.handle ) === false ) {
                    
jQuery.removeEventelemtypeelemData.handle );
                }

                
delete eventstype ];
            }
        }

        
// Remove the expando if it's no longer used
        
if ( jQuery.isEmptyObjectevents ) ) {
            
delete elemData.handle;
            
data_priv.removeelem"events" );
        }
    },

    
trigger: function( eventdataelemonlyHandlers ) {

        var 
icurtmpbubbleTypeontypehandlespecial,
            
eventPath = [ elem || document ],
            
type hasOwn.callevent"type" ) ? event.type event,
            
namespaces hasOwn.callevent"namespace" ) ? event.namespace.split(".") : [];

        
cur tmp elem elem || document;

        
// Don't do events on text and comment nodes
        
if ( elem.nodeType === || elem.nodeType === ) {
            return;
        }

        
// focus/blur morphs to focusin/out; ensure we're not firing them right now
        
if ( rfocusMorph.testtype jQuery.event.triggered ) ) {
            return;
        }

        if ( 
type.indexOf(".") >= ) {
            
// Namespaced trigger; create a regexp to match event type in handle()
            
namespaces type.split(".");
            
type namespaces.shift();
            
namespaces.sort();
        }
        
ontype type.indexOf(":") < && "on" type;

        
// Caller can pass in a jQuery.Event object, Object, or just an event type string
        
event eventjQuery.expando ] ?
            
event :
            new 
jQuery.Eventtypetypeof event === "object" && event );

        
// Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true)
        
event.isTrigger onlyHandlers 3;
        
event.namespace = namespaces.join(".");
        
event.namespace_re event.namespace ?
            new 
RegExp"(^|\.)" namespaces.join("\.(?:.*\.|)") + "(\.|$)" ) :
            
null;

        
// Clean up the event in case it is being reused
        
event.result undefined;
        if ( !
event.target ) {
            
event.target elem;
        }

        
// Clone any incoming data and prepend the event, creating the handler arg list
        
data data == null ?
            [ 
event ] :
            
jQuery.makeArraydata, [ event ] );

        
// Allow special events to draw outside the lines
        
special jQuery.event.specialtype ] || {};
        if ( !
onlyHandlers && special.trigger && special.trigger.applyelemdata ) === false ) {
            return;
        }

        
// Determine event propagation path in advance, per W3C events spec (#9951)
        // Bubble up to document, then to window; watch for a global ownerDocument var (#9724)
        
if ( !onlyHandlers && !special.noBubble && !jQuery.isWindowelem ) ) {

            
bubbleType special.delegateType || type;
            if ( !
rfocusMorph.testbubbleType type ) ) {
                
cur cur.parentNode;
            }
            for ( ; 
curcur cur.parentNode ) {
                
eventPath.pushcur );
                
tmp cur;
            }

            
// Only add window if we got to document (e.g., not plain obj or detached DOM)
            
if ( tmp === (elem.ownerDocument || document) ) {
                
eventPath.pushtmp.defaultView || tmp.parentWindow || window );
            }
        }

        
// Fire handlers on the event path
        
0;
        while ( (
cur eventPath[i++]) && !event.isPropagationStopped() ) {

            
event.type ?
                
bubbleType :
                
special.bindType || type;

            
// jQuery handler
            
handle = ( data_priv.getcur"events" ) || {} )[ event.type ] && data_priv.getcur"handle" );
            if ( 
handle ) {
                
handle.applycurdata );
            }

            
// Native handler
            
handle ontype && curontype ];
            if ( 
handle && handle.apply && jQuery.acceptDatacur ) ) {
                
event.result handle.applycurdata );
                if ( 
event.result === false ) {
                    
event.preventDefault();
                }
            }
        }
        
event.type type;

        
// If nobody prevented the default action, do it now
        
if ( !onlyHandlers && !event.isDefaultPrevented() ) {

            if ( (!
special._default || special._default.applyeventPath.pop(), data ) === false) &&
                
jQuery.acceptDataelem ) ) {

                
// Call a native DOM method on the target with the same name name as the event.
                // Don't do default actions on window, that's where global variables be (#6170)
                
if ( ontype && jQuery.isFunctionelemtype ] ) && !jQuery.isWindowelem ) ) {

                    
// Don't re-trigger an onFOO event when we call its FOO() method
                    
tmp elemontype ];

                    if ( 
tmp ) {
                        
elemontype ] = null;
                    }

                    
// Prevent re-triggering of the same event, since we already bubbled it above
                    
jQuery.event.triggered type;
                    
elemtype ]();
                    
jQuery.event.triggered undefined;

                    if ( 
tmp ) {
                        
elemontype ] = tmp;
                    }
                }
            }
        }

        return 
event.result;
    },

    
dispatch: function( event ) {

        
// Make a writable jQuery.Event from the native event object
        
event jQuery.event.fixevent );

        var 
ijretmatchedhandleObj,
            
handlerQueue = [],
            
args slice.callarguments ),
            
handlers = ( data_priv.getthis"events" ) || {} )[ event.type ] || [],
            
special jQuery.event.specialevent.type ] || {};

        
// Use the fix-ed jQuery.Event rather than the (read-only) native event
        
args[0] = event;
        
event.delegateTarget this;

        
// Call the preDispatch hook for the mapped type, and let it bail if desired
        
if ( special.preDispatch && special.preDispatch.callthisevent ) === false ) {
            return;
        }

        
// Determine handlers
        
handlerQueue jQuery.event.handlers.callthiseventhandlers );

        
// Run delegates first; they may want to stop propagation beneath us
        
0;
        while ( (
matched handlerQueuei++ ]) && !event.isPropagationStopped() ) {
            
event.currentTarget matched.elem;

            
0;
            while ( (
handleObj matched.handlersj++ ]) && !event.isImmediatePropagationStopped() ) {

                
// Triggered event must either 1) have no namespace, or 2) have namespace(s)
                // a subset or equal to those in the bound event (both can have no namespace).
                
if ( !event.namespace_re || event.namespace_re.testhandleObj.namespace ) ) {

                    
event.handleObj handleObj;
                    
event.data handleObj.data;

                    
ret = ( (jQuery.event.specialhandleObj.origType ] || {}).handle || handleObj.handler )
                            .
applymatched.elemargs );

                    if ( 
ret !== undefined ) {
                        if ( (
event.result ret) === false ) {
                            
event.preventDefault();
                            
event.stopPropagation();
                        }
                    }
                }
            }
        }

        
// Call the postDispatch hook for the mapped type
        
if ( special.postDispatch ) {
            
special.postDispatch.callthisevent );
        }

        return 
event.result;
    },

    
handlers: function( eventhandlers ) {
        var 
imatchesselhandleObj,
            
handlerQueue = [],
            
delegateCount handlers.delegateCount,
            
cur event.target;

        
// Find delegate handlers
        // Black-hole SVG <use> instance trees (#13180)
        // Avoid non-left-click bubbling in Firefox (#3861)
        
if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) {

            for ( ; 
cur !== thiscur cur.parentNode || this ) {

                
// Don't process clicks on disabled elements (#6911, #8165, #11382, #11764)
                
if ( cur.disabled !== true || event.type !== "click" ) {
                    
matches = [];
                    for ( 
0delegateCounti++ ) {
                        
handleObj handlers];

                        
// Don't conflict with Object.prototype properties (#13203)
                        
sel handleObj.selector " ";

                        if ( 
matchessel ] === undefined ) {
                            
matchessel ] = handleObj.needsContext ?
                                
jQueryselthis ).indexcur ) >= :
                                
jQuery.findselthisnull, [ cur ] ).length;
                        }
                        if ( 
matchessel ] ) {
                            
matches.pushhandleObj );
                        }
                    }
                    if ( 
matches.length ) {
                        
handlerQueue.push({ elemcurhandlersmatches });
                    }
                }
            }
        }

        
// Add the remaining (directly-bound) handlers
        
if ( delegateCount handlers.length ) {
            
handlerQueue.push({ elemthishandlershandlers.slicedelegateCount ) });
        }

        return 
handlerQueue;
    },

    
// Includes some event props shared by KeyEvent and MouseEvent
    
props"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),

    
fixHooks: {},

    
keyHooks: {
        
props"char charCode key keyCode".split(" "),
        
filter: function( eventoriginal ) {

            
// Add which for key events
            
if ( event.which == null ) {
                
event.which original.charCode != null original.charCode original.keyCode;
            }

            return 
event;
        }
    },

    
mouseHooks: {
        
props"button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "),
        
filter: function( eventoriginal ) {
            var 
eventDocdocbody,
                
button original.button;

            
// Calculate pageX/Y if missing and clientX/Y available
            
if ( event.pageX == null && original.clientX != null ) {
                
eventDoc event.target.ownerDocument || document;
                
doc eventDoc.documentElement;
                
body eventDoc.body;

                
event.pageX original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || ) - ( doc && doc.clientLeft || body && body.clientLeft || );
                
event.pageY original.clientY + ( doc && doc.scrollTop  || body && body.scrollTop  || ) - ( doc && doc.clientTop  || body && body.clientTop  || );
            }

            
// Add which for click: 1 === left; 2 === middle; 3 === right
            // Note: button is not normalized, so don't use it
            
if ( !event.which && button !== undefined ) {
                
event.which = ( button : ( button : ( button ) ) );
            }

            return 
event;
        }
    },

    
fix: function( event ) {
        if ( 
eventjQuery.expando ] ) {
            return 
event;
        }

        
// Create a writable copy of the event object and normalize some properties
        
var ipropcopy,
            
type event.type,
            
originalEvent event,
            
fixHook this.fixHookstype ];

        if ( !
fixHook ) {
            
this.fixHookstype ] = fixHook =
                
rmouseEvent.testtype ) ? this.mouseHooks :
                
rkeyEvent.testtype ) ? this.keyHooks :
                {};
        }
        
copy fixHook.props this.props.concatfixHook.props ) : this.props;

        
event = new jQuery.EventoriginalEvent );

        
copy.length;
        while ( 
i-- ) {
            
prop copy];
            
eventprop ] = originalEventprop ];
        }

        
// Support: Cordova 2.5 (WebKit) (#13255)
        // All events should have a target; Cordova deviceready doesn't
        
if ( !event.target ) {
            
event.target document;
        }

        
// Support: Safari 6.0+, Chrome<28
        // Target should not be a text node (#504, #13143)
        
if ( event.target.nodeType === ) {
            
event.target event.target.parentNode;
        }

        return 
fixHook.filter fixHook.filtereventoriginalEvent ) : event;
    },

    
special: {
        
load: {
            
// Prevent triggered image.load events from bubbling to window.load
            
noBubbletrue
        
},
        
focus: {
            
// Fire native event if possible so blur/focus sequence is correct
            
trigger: function() {
                if ( 
this !== safeActiveElement() && this.focus ) {
                    
this.focus();
                    return 
false;
                }
            },
            
delegateType"focusin"
        
},
        
blur: {
            
trigger: function() {
                if ( 
this === safeActiveElement() && this.blur ) {
                    
this.blur();
                    return 
false;
                }
            },
            
delegateType"focusout"
        
},
        
click: {
            
// For checkbox, fire native event so checked state will be right
            
trigger: function() {
                if ( 
this.type === "checkbox" && this.click && jQuery.nodeNamethis"input" ) ) {
                    
this.click();
                    return 
false;
                }
            },

            
// For cross-browser consistency, don't fire native .click() on links
            
_default: function( event ) {
                return 
jQuery.nodeNameevent.target"a" );
            }
        },

        
beforeunload: {
            
postDispatch: function( event ) {

                
// Support: Firefox 20+
                // Firefox doesn't alert if the returnValue field is not set.
                
if ( event.result !== undefined && event.originalEvent ) {
                    
event.originalEvent.returnValue event.result;
                }
            }
        }
    },

    
simulate: function( typeelemeventbubble ) {
        
// Piggyback on a donor event to simulate a different one.
        // Fake originalEvent to avoid donor's stopPropagation, but if the
        // simulated event prevents default then we do the same on the donor.
        
var jQuery.extend(
            new 
jQuery.Event(),
            
event,
            {
                
typetype,
                
isSimulatedtrue,
                
originalEvent: {}
            }
        );
        if ( 
bubble ) {
            
jQuery.event.triggerenullelem );
        } else {
            
jQuery.event.dispatch.callelem);
        }
        if ( 
e.isDefaultPrevented() ) {
            
event.preventDefault();
        }
    }
};

jQuery.removeEvent = function( elemtypehandle ) {
    if ( 
elem.removeEventListener ) {
        
elem.removeEventListenertypehandlefalse );
    }
};

jQuery.Event = function( srcprops ) {
    
// Allow instantiation without the 'new' keyword
    
if ( !(this instanceof jQuery.Event) ) {
        return new 
jQuery.Eventsrcprops );
    }

    
// Event object
    
if ( src && src.type ) {
        
this.originalEvent src;
        
this.type src.type;

        
// Events bubbling up the document may have been marked as prevented
        // by a handler lower down the tree; reflect the correct value.
        
this.isDefaultPrevented src.defaultPrevented ||
                
src.defaultPrevented === undefined &&
                
// Support: Android<4.0
                
src.returnValue === false ?
            
returnTrue :
            
returnFalse;

    
// Event type
    
} else {
        
this.type src;
    }

    
// Put explicitly provided properties onto the event object
    
if ( props ) {
        
jQuery.extendthisprops );
    }

    
// Create a timestamp if incoming event doesn't have one
    
this.timeStamp src && src.timeStamp || jQuery.now();

    
// Mark it as fixed
    
thisjQuery.expando ] = true;
};

// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding
// http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html
jQuery.Event.prototype = {
    
isDefaultPreventedreturnFalse,
    
isPropagationStoppedreturnFalse,
    
isImmediatePropagationStoppedreturnFalse,

    
preventDefault: function() {
        var 
this.originalEvent;

        
this.isDefaultPrevented returnTrue;

        if ( 
&& e.preventDefault ) {
            
e.preventDefault();
        }
    },
    
stopPropagation: function() {
        var 
this.originalEvent;

        
this.isPropagationStopped returnTrue;

        if ( 
&& e.stopPropagation ) {
            
e.stopPropagation();
        }
    },
    
stopImmediatePropagation: function() {
        var 
this.originalEvent;

        
this.isImmediatePropagationStopped returnTrue;

        if ( 
&& e.stopImmediatePropagation ) {
            
e.stopImmediatePropagation();
        }

        
this.stopPropagation();
    }
};

// Create mouseenter/leave events using mouseover/out and event-time checks
// Support: Chrome 15+
jQuery.each({
    
mouseenter"mouseover",
    
mouseleave"mouseout",
    
pointerenter"pointerover",
    
pointerleave"pointerout"
}, function( origfix ) {
    
jQuery.event.specialorig ] = {
        
delegateTypefix,
        
bindTypefix,

        
handle: function( event ) {
            var 
ret,
                
target this,
                
related event.relatedTarget,
                
handleObj event.handleObj;

            
// For mousenter/leave call the handler if related is outside the target.
            // NB: No relatedTarget if the mouse left/entered the browser window
            
if ( !related || (related !== target && !jQuery.containstargetrelated )) ) {
                
event.type handleObj.origType;
                
ret handleObj.handler.applythisarguments );
                
event.type fix;
            }
            return 
ret;
        }
    };
});

// Support: Firefox, Chrome, Safari
// Create "bubbling" focus and blur events
if ( !support.focusinBubbles ) {
    
jQuery.each({ focus"focusin"blur"focusout" }, function( origfix ) {

        
// Attach a single capturing handler on the document while someone wants focusin/focusout
        
var handler = function( event ) {
                
jQuery.event.simulatefixevent.targetjQuery.event.fixevent ), true );
            };

        
jQuery.event.specialfix ] = {
            
setup: function() {
                var 
doc this.ownerDocument || this,
                    
attaches data_priv.accessdocfix );

                if ( !
attaches ) {
                    
doc.addEventListenerorighandlertrue );
                }
                
data_priv.accessdocfix, ( attaches || ) + );
            },
            
teardown: function() {
                var 
doc this.ownerDocument || this,
                    
attaches data_priv.accessdocfix ) - 1;

                if ( !
attaches ) {
                    
doc.removeEventListenerorighandlertrue );
                    
data_priv.removedocfix );

                } else {
                    
data_priv.accessdocfixattaches );
                }
            }
        };
    });
}

jQuery.fn.extend({

    
on: function( typesselectordata, fn, /*INTERNAL*/ one ) {
        var 
origFntype;

        
// Types can be a map of types/handlers
        
if ( typeof types === "object" ) {
            
// ( types-Object, selector, data )
            
if ( typeof selector !== "string" ) {
                
// ( types-Object, data )
                
data data || selector;
                
selector undefined;
            }
            for ( 
type in types ) {
                
this.ontypeselectordatatypestype ], one );
            }
            return 
this;
        }

        if ( 
data == null && fn == null ) {
            
// ( types, fn )
            
fn = selector;
            
data selector undefined;
        } else if ( fn == 
null ) {
            if ( 
typeof selector === "string" ) {
                
// ( types, selector, fn )
                
fn = data;
                
data undefined;
            } else {
                
// ( types, data, fn )
                
fn = data;
                
data selector;
                
selector undefined;
            }
        }
        if ( fn === 
false ) {
            fn = 
returnFalse;
        } else if ( !fn ) {
            return 
this;
        }

        if ( 
one === ) {
            
origFn = fn;
            fn = function( 
event ) {
                
// Can use an empty set, since event contains the info
                
jQuery().offevent );
                return 
origFn.applythisarguments );
            };
            
// Use same guid so caller can remove using origFn
            
fn.guid origFn.guid || ( origFn.guid jQuery.guid++ );
        }
        return 
this.each( function() {
            
jQuery.event.addthistypes, fn, dataselector );
        });
    },
    
one: function( typesselectordata, fn ) {
        return 
this.ontypesselectordata, fn, );
    },
    
off: function( typesselector, fn ) {
        var 
handleObjtype;
        if ( 
types && types.preventDefault && types.handleObj ) {
            
// ( event )  dispatched jQuery.Event
            
handleObj types.handleObj;
            
jQuerytypes.delegateTarget ).off(
                
handleObj.namespace ? handleObj.origType "." handleObj.namespace : handleObj.origType,
                
handleObj.selector,
                
handleObj.handler
            
);
            return 
this;
        }
        if ( 
typeof types === "object" ) {
            
// ( types-object [, selector] )
            
for ( type in types ) {
                
this.offtypeselectortypestype ] );
            }
            return 
this;
        }
        if ( 
selector === false || typeof selector === "function" ) {
            
// ( types [, fn] )
            
fn = selector;
            
selector undefined;
        }
        if ( fn === 
false ) {
            fn = 
returnFalse;
        }
        return 
this.each(function() {
            
jQuery.event.removethistypes, fn, selector );
        });
    },

    
trigger: function( typedata ) {
        return 
this.each(function() {
            
jQuery.event.triggertypedatathis );
        });
    },
    
triggerHandler: function( typedata ) {
        var 
elem this[0];
        if ( 
elem ) {
            return 
jQuery.event.triggertypedataelemtrue );
        }
    }
});

return 
jQuery;
});
?>
Онлайн: 1
Реклама