


In-depth understanding of the immediate execution function (function(){…})()_Basic knowledge in JavaScript
Javascript is relatively casual compared to other programming languages, so the JavaScript code is full of all kinds of weird writing methods, which can sometimes seem like smoke and mirrors. Of course, being able to understand all kinds of writing methods is also a deeper understanding of the characteristics of the JavaScript language.
( function(){…} )() and ( function (){…} () ) are two common ways of writing JavaScript functions to execute immediately. At first, I thought it was an anonymous function wrapped in parentheses, and then added The parentheses call the function, and finally achieve the purpose of executing the function immediately after it is defined. Later, it was discovered that the reason for adding the parentheses was not the same. To understand the immediate execution of functions, you need to first understand some basic concepts of functions.
Function declaration, function expression, anonymous function
Function declaration: function fnName () {…}; Use the function keyword to declare a function, and then specify a function name, which is called a function declaration.
Function expression var fnName = function () {…}; Use the function keyword to declare a function, but do not give the function a name. Finally, the anonymous function is assigned to a variable, called a function expression. This is the most common function expression. grammatical form.
Anonymous function: function () {}; Use the function keyword to declare a function, but do not give the function a name, so it is called an anonymous function. Anonymous functions belong to function expressions. Anonymous functions have many functions. When assigned to a variable, a function is created , assigning an event becomes an event handler or creates a closure, etc.
The difference between function declaration and function expression is that 1. When the Javascript engine parses the javascript code, it will 'function declaration hoisting' the function declaration on the current execution environment (scope), while the function expression You must wait until the Javascirtp engine reaches the line where it is executed before parsing the function expression line by line from top to bottom. 2. You can add parentheses after the function expression to call the function immediately. Function declaration is not allowed and can only be called fnName() form call. Here are two examples of the difference.
fnName();
function fnName(){
…
}
//Normal, because the function declaration is 'promoted', the function call can be made before the function declaration
fnName();
var fnName=function( ){
…
}
//Error, the variable fnName has not saved a reference to the function, the function call must be after the function expression
var fnName=function(){
alert( 'Hello World');
}();
//Add parentheses after the function expression. When the javascript engine parses this, the function can be called immediately
function fnName(){
alert( 'Hello World');
}();
//No error will be reported, but the javascript engine only parses the function declaration and ignores the following brackets. The function declaration will not be called
function(){
console.log('Hello World');
}();
//Syntax error, although the anonymous function is a function expression, no assignment operation is performed,
//So the javascript engine will start The function keyword is used as a function declaration, and an error is reported: A function name is required
After understanding some basic concepts of functions, I looked back at the two ways of writing functions that execute functions immediately (function(){…})() and (function (){…} ()). At first, I thought they were the same Wrap an anonymous function in parentheses, and add a parentheses after it to call the function immediately. I didn’t know why the parentheses were added at the time, but later I realized that if you want to add parentheses after the function body to call it immediately, the function must be a function expression, not a function declaration. .
(function(a){
console.log (a); //firebug output 123, use () operator
})(123);
(function(a){
console.log(a); //firebug output 1234, use () operator
}(1234));
!function(a){
console.log(a); //firebug output 12345, use! Operator
}(12345);
function(a){
console.log(a); //firebug output 123456, use operator
}(123456);
-function(a){
console.log(a); //firebug output 1234567, use - operator
}(1234567);
var fn=function(a ){
console.log(a); //firebug output 12345678, use = operator
}(12345678)
To see the output, add it in front of function! , , - or even commas can have the effect of executing the function immediately after it is defined, while (),! Operators such as , , - and = all convert function declarations into function expressions, eliminating the ambiguity between the JavaScript engine in identifying function expressions and function declarations, and telling the JavaScript engine that this is a function expression, not a function declaration, and can be used later. Add parentheses and execute the function's code immediately.
Adding parentheses is the safest thing to do, because! Operators such as , , - will also perform operations with the return value of the function, sometimes causing unnecessary trouble.
But what is the use of writing like this?
There is no concept of private scope in JavaScript. If you declare some variables in the global or local scope on a project developed by multiple people, they may be overwritten by other people accidentally using variables with the same name. According to the characteristics of JavaScript function scope chain, this technology can be used to imitate a private scope and use anonymous functions as a "container". External variables can be accessed inside the "container", but the external environment cannot access the variables inside the "container". variables, so the variables defined inside (function(){…})()() will not conflict with external variables, commonly known as "anonymous wrapper" or "namespace".
JQuery uses this method. Wrap the JQuery code in (function (window, undefined){...jquery code...} (window). When calling the JQuery code in the global scope, you can protect JQuery internal variables.
This article is a compilation of personal understanding. If there are any errors, please point them out. The views in the article are referenced from:
"Javascript Authoritative Guide", "Javascript Advanced Programming"

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

How to use WebSocket and JavaScript to implement an online speech recognition system Introduction: With the continuous development of technology, speech recognition technology has become an important part of the field of artificial intelligence. The online speech recognition system based on WebSocket and JavaScript has the characteristics of low latency, real-time and cross-platform, and has become a widely used solution. This article will introduce how to use WebSocket and JavaScript to implement an online speech recognition system.

WebSocket and JavaScript: Key technologies for realizing real-time monitoring systems Introduction: With the rapid development of Internet technology, real-time monitoring systems have been widely used in various fields. One of the key technologies to achieve real-time monitoring is the combination of WebSocket and JavaScript. This article will introduce the application of WebSocket and JavaScript in real-time monitoring systems, give code examples, and explain their implementation principles in detail. 1. WebSocket technology

How to use WebSocket and JavaScript to implement an online reservation system. In today's digital era, more and more businesses and services need to provide online reservation functions. It is crucial to implement an efficient and real-time online reservation system. This article will introduce how to use WebSocket and JavaScript to implement an online reservation system, and provide specific code examples. 1. What is WebSocket? WebSocket is a full-duplex method on a single TCP connection.

Introduction to how to use JavaScript and WebSocket to implement a real-time online ordering system: With the popularity of the Internet and the advancement of technology, more and more restaurants have begun to provide online ordering services. In order to implement a real-time online ordering system, we can use JavaScript and WebSocket technology. WebSocket is a full-duplex communication protocol based on the TCP protocol, which can realize real-time two-way communication between the client and the server. In the real-time online ordering system, when the user selects dishes and places an order

JavaScript and WebSocket: Building an efficient real-time weather forecast system Introduction: Today, the accuracy of weather forecasts is of great significance to daily life and decision-making. As technology develops, we can provide more accurate and reliable weather forecasts by obtaining weather data in real time. In this article, we will learn how to use JavaScript and WebSocket technology to build an efficient real-time weather forecast system. This article will demonstrate the implementation process through specific code examples. We

JavaScript tutorial: How to get HTTP status code, specific code examples are required. Preface: In web development, data interaction with the server is often involved. When communicating with the server, we often need to obtain the returned HTTP status code to determine whether the operation is successful, and perform corresponding processing based on different status codes. This article will teach you how to use JavaScript to obtain HTTP status codes and provide some practical code examples. Using XMLHttpRequest

Introduction to the method of obtaining HTTP status code in JavaScript: In front-end development, we often need to deal with the interaction with the back-end interface, and HTTP status code is a very important part of it. Understanding and obtaining HTTP status codes helps us better handle the data returned by the interface. This article will introduce how to use JavaScript to obtain HTTP status codes and provide specific code examples. 1. What is HTTP status code? HTTP status code means that when the browser initiates a request to the server, the service

Usage: In JavaScript, the insertBefore() method is used to insert a new node in the DOM tree. This method requires two parameters: the new node to be inserted and the reference node (that is, the node where the new node will be inserted).
