jQuery ready function aliases

后端 未结 3 1673
醉话见心
醉话见心 2021-01-05 16:38

I\'m a little confused about all the different ways to create a new jQuery object.

the relevent docs seem to be: http://api.jquery.com/ready/ http://api.jquery.c

相关标签:
3条回答
  • 2021-01-05 16:45

    Well, there is another. From the docs:

    There is also $(document).bind("ready", handler). This behaves similarly to the ready
    method but with one exception: If the ready event has already fired and you try to .bind("ready") the bound handler will not be executed.

    The other initialiser methods will always run... so you might find yourself declaring $(document).ready(function() { //stuff } in a number of files for example, and the handler is always run.

    I'd go with jQuery(document).ready(function($) {}) or $(document).ready(function() {}) more often than not... I find that they're more readable.

    Another approach would be to call a script just before the closing body tag and in it do something like,

    (function($) {
        //stuff
    })(jQuery);
    

    if you need to avoid conflicts with other libraries using $. This is a self-executing anonymous function and it lets you use the alias in its scope without fear of conflicts from other libraries.

    0 讨论(0)
  • 2021-01-05 16:55

    Well if you are only using jQuery then $() is equivalent to jQuery(). So that covers half of them.

    Then, if you use $() instead of $(document).ready, those are the same. In this case, it is just a helper function. You may want to add ready on something else for example, in which case, you would do: $(foo).load({})

    Last, I don't know what you mean with $().ready because you have to pass a parameter.

    0 讨论(0)
  • 2021-01-05 16:58

    These are somewhat equivalent:

    • $(document).ready(handler) - tuns the handler when the DOM is loaded
    • $().ready(handler) - runs the handler when the DOM is loaded (deprecated, don't use)
    • $(handler) - runs the handler then the DOM is loaded - shortcut to $(document).ready(handler)
    • jQuery(function($) {}) same as #3 above, just using jQuery instead of the $ alias
    • jQuery(document).ready(function($) {}) - same as the first, again using jQuery instead of the $ alias

    If $ is defined as something else, e.g. Prototype, then the first 3 won't work. The last 2 are similiar they're just accepting the first argument passed in (the jQuery object) and making it $ inside, making it possible to do this even when $ is something else:

    jQuery(function($) {
      $("input").val("something");
    });
    
    0 讨论(0)
提交回复
热议问题