For example, the following code
{
var temp = "12";
}
alert(temp); //Output 12
If according to the usual programming experience, the alert function cannot access the temp variable because it In another block, but in JavaScript, there is no concept of block scope, so this syntax does not work for JS, but when we write JS programs, especially larger programs or libraries, in order To prevent naming conflicts, a mechanism for controlling variable scope is needed, so here is a more common way to implement the concept of block scope. The code is as follows:
(function() {
var temp = "123";
})();
alert(temp); //Output error
As in the above code, a function expression is defined and then called immediately. This form imitates the concept of block scope and protects the contents of the block. namespace, this method is very useful in some larger program libraries
(such as JQuery), and effectively avoids naming conflicts. In fact, JQuery uses this method to implement block scope.