Understanding javascript callback functions_basic knowledge
Pass the function as a parameter into another function. This function is the so-called callback function
We often encounter a situation where the A and B layers of a project are completed by different people. The A layer is responsible for the function funA, and the B layer is responsible for funcB. When layer B wants to use data from a certain module, he says to the people at layer A, I need you to provide data that meets certain needs, and you provide me with an interface.
The personnel at level A said: I will provide you with data, and how to display and process it is B’s business.
Of course, layer B cannot provide a data interface for every need. B provides an interface for A to pass through. B gets the data, and then B writes a function to display it.
That is, you need to cooperate with other people, others provide data, and you do not need to pay attention to how others obtain or construct data. You just need to operate on the obtained data. At this time, you need to use the callback function
Therefore, callbacks are essentially a design pattern, and the design principles of jQuery (including other frameworks) follow this pattern.
An example of using callbacks in synchronization (blocking), the purpose is to execute func2 after the execution of func1 code is completed.
var func1=function(callback){
//do something.
(callback && typeof(callback) === "function") && callback();
}
func1(func2);
var func2=function(){
}
Example of asynchronous callback:
$(document).ready(callback);
$.ajax({
url: "test.html",
context: document.body
}).done(function() {
$(this).addClass("done");
}).fail(function() {
alert("error");
}).always(function() {
alert("complete");
});
Note that the ajax request is indeed asynchronous, but this request is requested by the browser to open a new thread. When the status of the request changes, if a callback has been set previously, the asynchronous thread will generate a status change event and put it in Waiting for processing in the processing queue of the JavaScript engine. See: http://www.phpv.net/html/1700.html
When will the callback be executed?
The callback function is generally executed last in a synchronous situation, but may not be executed in an asynchronous situation because the event is not triggered or the conditions are not met.
Usage occasions of callback function
Resource loading: execute callback after dynamically loading js files, execute callback after loading iframe, ajax operation callback, execute callback after image loading is completed, AJAX, etc.
DOM events and Node.js events are based on the callback mechanism (Node.js callbacks may have multi-layer callback nesting problems).
The delay time of setTimeout is 0. This hack is often used. The function called by settimeout is actually the embodiment of a callback
Chained calls: When chained, it is easy to implement chained calls in the assignor (setter) method (or in a method that does not return a value itself), but the getter (getter) is relatively difficult to implement. Implement chained calls, because you need the valuer to return the data you need instead of this pointer. If you want to implement a chained method, you can use a callback function to implement it
The function calls of setTimeout and setInterval get their return values. Since both functions are asynchronous, that is, their calling sequence is relatively independent of the main process of the program, there is no way to wait for their return values in the body, and the program will not stop and wait when they are opened. Otherwise, the meaning of setTimeout and setInterval will be lost, so it is meaningless to use return, and callback can only be used. The meaning of callback is to notify the agent function of the result of timer execution for timely processing.
Collect information online and you should understand it. I can sort out an example myself:
function fun(num,callback){
If(num alert("Calling layer A function for processing!");
alert("Data cannot be negative, input error!");
}else if(num==0){
alert("Calling layer A function for processing!");
alert("This data item does not exist!");
}else{
alert("Call B layer function processing!");
callback(1);
}
}
function test(){
var num=document.getElementById("score").value;
Fun(num,function(back){ //Anonymous B layer processing function
alert(":" back);
If(num alert("The number is 1");
else if(num alert("The number is 2 or 3!");
else
alert("The number is greater than 3!");
})
}
When the function starts to execute fun, it first runs to determine whether num is a negative number or zero, otherwise it executes the B layer processing function alert(":" back); outputs 1 and determines as 3 and other situations.
Experience tips:
It is best to ensure that the callback exists and must be a function reference or function expression:
(callback && typeof(callback) === "function") && callback();
var obj={
init: function(callback){
//TODO...
If(callback && typeof(callback) === "function") && callback()){
callback('init...');//Callback
}
}
Finally, why should we use callback functions? The following metaphor is very vivid and interesting.
If you have something to do, you go to the next door dormitory to look for your classmates and find that they are not there. What should you do?
Method 1, go to the next door dormitory every few minutes to see if anyone is there
Method 2, please ask the people who share the same dormitory with him to call you when they see him coming back
The former is polling and the latter is callback.
Then tell me, can I just wait in the next dormitory until my classmates come back?
Yes, it’s just that you could have saved time to do other things, but now you have to waste it waiting. Turn the original non-blocking asynchronous call into a blocking synchronous call.
JavaScript callbacks are used in asynchronous calling scenarios, and the performance of using callbacks is better than polling.

Understanding how JavaScript engine works internally is important to developers because it helps write more efficient code and understand performance bottlenecks and optimization strategies. 1) The engine's workflow includes three stages: parsing, compiling and execution; 2) During the execution process, the engine will perform dynamic optimization, such as inline cache and hidden classes; 3) Best practices include avoiding global variables, optimizing loops, using const and lets, and avoiding excessive use of closures.

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

The shift from C/C to JavaScript requires adapting to dynamic typing, garbage collection and asynchronous programming. 1) C/C is a statically typed language that requires manual memory management, while JavaScript is dynamically typed and garbage collection is automatically processed. 2) C/C needs to be compiled into machine code, while JavaScript is an interpreted language. 3) JavaScript introduces concepts such as closures, prototype chains and Promise, which enhances flexibility and asynchronous programming capabilities.

Different JavaScript engines have different effects when parsing and executing JavaScript code, because the implementation principles and optimization strategies of each engine differ. 1. Lexical analysis: convert source code into lexical unit. 2. Grammar analysis: Generate an abstract syntax tree. 3. Optimization and compilation: Generate machine code through the JIT compiler. 4. Execute: Run the machine code. V8 engine optimizes through instant compilation and hidden class, SpiderMonkey uses a type inference system, resulting in different performance performance on the same code.

JavaScript's applications in the real world include server-side programming, mobile application development and Internet of Things control: 1. Server-side programming is realized through Node.js, suitable for high concurrent request processing. 2. Mobile application development is carried out through ReactNative and supports cross-platform deployment. 3. Used for IoT device control through Johnny-Five library, suitable for hardware interaction.

I built a functional multi-tenant SaaS application (an EdTech app) with your everyday tech tool and you can do the same. First, what’s a multi-tenant SaaS application? Multi-tenant SaaS applications let you serve multiple customers from a sing

This article demonstrates frontend integration with a backend secured by Permit, building a functional EdTech SaaS application using Next.js. The frontend fetches user permissions to control UI visibility and ensures API requests adhere to role-base


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

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

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool

Safe Exam Browser
Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 Linux new version
SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.