1 | define([
|
2 | "../core",
|
3 | "../core/init",
|
4 | "../deferred"
|
5 | ], function( jQuery ) {
|
6 |
|
7 |
|
8 | var readyList;
|
9 |
|
10 | jQuery.fn.ready = function( fn ) {
|
11 |
|
12 | jQuery.ready.promise().done( fn );
|
13 |
|
14 | return this;
|
15 | };
|
16 |
|
17 | jQuery.extend({
|
18 |
|
19 | isReady: false,
|
20 |
|
21 |
|
22 |
|
23 | readyWait: 1,
|
24 |
|
25 |
|
26 | holdReady: function( hold ) {
|
27 | if ( hold ) {
|
28 | jQuery.readyWait++;
|
29 | } else {
|
30 | jQuery.ready( true );
|
31 | }
|
32 | },
|
33 |
|
34 |
|
35 | ready: function( wait ) {
|
36 |
|
37 |
|
38 | if ( wait === true ? --jQuery.readyWait : jQuery.isReady ) {
|
39 | return;
|
40 | }
|
41 |
|
42 |
|
43 | jQuery.isReady = true;
|
44 |
|
45 |
|
46 | if ( wait !== true && --jQuery.readyWait > 0 ) {
|
47 | return;
|
48 | }
|
49 |
|
50 |
|
51 | readyList.resolveWith( document, [ jQuery ] );
|
52 |
|
53 |
|
54 | if ( jQuery.fn.triggerHandler ) {
|
55 | jQuery( document ).triggerHandler( "ready" );
|
56 | jQuery( document ).off( "ready" );
|
57 | }
|
58 | }
|
59 | });
|
60 |
|
61 |
|
62 |
|
63 |
|
64 | function completed() {
|
65 | document.removeEventListener( "DOMContentLoaded", completed, false );
|
66 | window.removeEventListener( "load", completed, false );
|
67 | jQuery.ready();
|
68 | }
|
69 |
|
70 | jQuery.ready.promise = function( obj ) {
|
71 | if ( !readyList ) {
|
72 |
|
73 | readyList = jQuery.Deferred();
|
74 |
|
75 |
|
76 |
|
77 |
|
78 | if ( document.readyState === "complete" ) {
|
79 |
|
80 | setTimeout( jQuery.ready );
|
81 |
|
82 | } else {
|
83 |
|
84 |
|
85 | document.addEventListener( "DOMContentLoaded", completed, false );
|
86 |
|
87 |
|
88 | window.addEventListener( "load", completed, false );
|
89 | }
|
90 | }
|
91 | return readyList.promise( obj );
|
92 | };
|
93 |
|
94 |
|
95 | jQuery.ready.promise();
|
96 |
|
97 | });
|