1
|
define( [
|
2
|
"../core",
|
3
|
"../var/document",
|
4
|
"../core/readyException",
|
5
|
"../deferred"
|
6
|
], function( jQuery, document ) {
|
7
|
|
8
|
"use strict";
|
9
|
|
10
|
// The deferred used on DOM ready
|
11
|
var readyList = jQuery.Deferred();
|
12
|
|
13
|
jQuery.fn.ready = function( fn ) {
|
14
|
|
15
|
readyList
|
16
|
.then( fn )
|
17
|
|
18
|
// Wrap jQuery.readyException in a function so that the lookup
|
19
|
// happens at the time of error handling instead of callback
|
20
|
// registration.
|
21
|
.catch( function( error ) {
|
22
|
jQuery.readyException( error );
|
23
|
} );
|
24
|
|
25
|
return this;
|
26
|
};
|
27
|
|
28
|
jQuery.extend( {
|
29
|
|
30
|
// Is the DOM ready to be used? Set to true once it occurs.
|
31
|
isReady: false,
|
32
|
|
33
|
// A counter to track how many items to wait for before
|
34
|
// the ready event fires. See #6781
|
35
|
readyWait: 1,
|
36
|
|
37
|
// Handle when the DOM is ready
|
38
|
ready: function( wait ) {
|
39
|
|
40
|
// Abort if there are pending holds or we're already ready
|
41
|
if ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {
|
42
|
return;
|
43
|
}
|
44
|
|
45
|
// Remember that the DOM is ready
|
46
|
jQuery.isReady = true;
|
47
|
|
48
|
// If a normal DOM Ready event fired, decrement, and wait if need be
|
49
|
if ( wait !== true && --jQuery.readyWait > 0 ) {
|
50
|
return;
|
51
|
}
|
52
|
|
53
|
// If there are functions bound, to execute
|
54
|
readyList.resolveWith( document, [ jQuery ] );
|
55
|
}
|
56
|
} );
|
57
|
|
58
|
jQuery.ready.then = readyList.then;
|
59
|
|
60
|
// The ready event handler and self cleanup method
|
61
|
function completed() {
|
62
|
document.removeEventListener( "DOMContentLoaded", completed );
|
63
|
window.removeEventListener( "load", completed );
|
64
|
jQuery.ready();
|
65
|
}
|
66
|
|
67
|
// Catch cases where $(document).ready() is called
|
68
|
// after the browser event has already occurred.
|
69
|
// Support: IE <=9 - 10 only
|
70
|
// Older IE sometimes signals "interactive" too soon
|
71
|
if ( document.readyState === "complete" ||
|
72
|
( document.readyState !== "loading" && !document.documentElement.doScroll ) ) {
|
73
|
|
74
|
// Handle it asynchronously to allow scripts the opportunity to delay ready
|
75
|
window.setTimeout( jQuery.ready );
|
76
|
|
77
|
} else {
|
78
|
|
79
|
// Use the handy event callback
|
80
|
document.addEventListener( "DOMContentLoaded", completed );
|
81
|
|
82
|
// A fallback to window.onload, that will always work
|
83
|
window.addEventListener( "load", completed );
|
84
|
}
|
85
|
|
86
|
} );
|