


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"

JavaScript originated in 1995 and was created by Brandon Ike, and realized the language into C. 1.C language provides high performance and system-level programming capabilities for JavaScript. 2. JavaScript's memory management and performance optimization rely on C language. 3. The cross-platform feature of C language helps JavaScript run efficiently on different operating systems.

JavaScript runs in browsers and Node.js environments and relies on the JavaScript engine to parse and execute code. 1) Generate abstract syntax tree (AST) in the parsing stage; 2) convert AST into bytecode or machine code in the compilation stage; 3) execute the compiled code in the execution stage.

The future trends of Python and JavaScript include: 1. Python will consolidate its position in the fields of scientific computing and AI, 2. JavaScript will promote the development of web technology, 3. Cross-platform development will become a hot topic, and 4. Performance optimization will be the focus. Both will continue to expand application scenarios in their respective fields and make more breakthroughs in performance.

Both Python and JavaScript's choices in development environments are important. 1) Python's development environment includes PyCharm, JupyterNotebook and Anaconda, which are suitable for data science and rapid prototyping. 2) The development environment of JavaScript includes Node.js, VSCode and Webpack, which are suitable for front-end and back-end development. Choosing the right tools according to project needs can improve development efficiency and project success rate.

Yes, the engine core of JavaScript is written in C. 1) The C language provides efficient performance and underlying control, which is suitable for the development of JavaScript engine. 2) Taking the V8 engine as an example, its core is written in C, combining the efficiency and object-oriented characteristics of C. 3) The working principle of the JavaScript engine includes parsing, compiling and execution, and the C language plays a key role in these processes.

JavaScript is at the heart of modern websites because it enhances the interactivity and dynamicity of web pages. 1) It allows to change content without refreshing the page, 2) manipulate web pages through DOMAPI, 3) support complex interactive effects such as animation and drag-and-drop, 4) optimize performance and best practices to improve user experience.

C and JavaScript achieve interoperability through WebAssembly. 1) C code is compiled into WebAssembly module and introduced into JavaScript environment to enhance computing power. 2) In game development, C handles physics engines and graphics rendering, and JavaScript is responsible for game logic and user interface.

JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.


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

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SublimeText3 Chinese version
Chinese version, very easy to use

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
