Mercurial > nebulaweb3
comparison default/node_modules/jquery/src/core/ready.js @ 0:1d038bc9b3d2 default tip
Up:default
author | Liny <dev@neowd.com> |
---|---|
date | Sat, 31 May 2025 09:21:51 +0800 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:1d038bc9b3d2 |
---|---|
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 } ); |