Dollar sign before self declaring anonymous function in JavaScript?

前端 未结 5 1500
闹比i
闹比i 2020-11-29 03:08

What is the difference between these two:

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

AND

(function () {
    // do stuff
})();


        
相关标签:
5条回答
  • 2020-11-29 03:23

    They are both anonymous functions, but (function(){})() is called immediately, and $(function(){}) is called when the document is ready.

    jQuery works something like this.

    window.jQuery = window.$ = function(arg) {
        if (typeof arg == 'function') {
            // call arg() when document is ready
        } else {
           // do other magics
        }
    }
    

    So you're just calling the jQuery function and passing in a function, which will be called on document ready.

    The 'Self-executing anonymous function' is the same as doing this.

    function a(){
        // do stuff
    }
    a();
    

    The only difference is that you are not polluting the global namespace.

    0 讨论(0)
  • 2020-11-29 03:26

    $(function() {}); is a jQuery shortcut for

     $(document).ready(function() { 
         /* Handler for .ready() called. */ 
     });
    

    While (function() {})(); is a instantly invoked function expression, or IIFE. This means that its an expression (not a statement) and it is invoked instantly after it is created.

    0 讨论(0)
  • 2020-11-29 03:41

    The first uses jQuery to bind a function to the document.ready event. The second declares and immediately executes a function.

    0 讨论(0)
  • 2020-11-29 03:42

    one is a jquery $(document).ready function and the other is just an anonymous function that calls itself.

    0 讨论(0)
  • 2020-11-29 03:42
    $(function () {
        // It will invoked after document is ready
    });
    

    This function execution once documents get ready mean, the whole HTML should get loaded before its execution but in the second case, the function invoked instantly after it is created.

    (function () {
        // It will invoked instantly after it is created
    })();
    
    0 讨论(0)
提交回复
热议问题