search
HomeWeb Front-endJS TutorialUnderstanding 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.

Copy code The code is as follows:

var func1=function(callback){
//do something.
(callback && typeof(callback) === "function") && callback();
}

func1(func2);
var func2=function(){
}

Example of asynchronous callback:

Copy code The code is as follows:

$(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:

Copy code The code is as follows:

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:

Copy code The code is as follows:

(callback && typeof(callback) === "function") && callback();

Copy code The code is as follows:

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.

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Understanding the JavaScript Engine: Implementation DetailsUnderstanding the JavaScript Engine: Implementation DetailsApr 17, 2025 am 12:05 AM

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 vs. JavaScript: The Learning Curve and Ease of UsePython vs. JavaScript: The Learning Curve and Ease of UseApr 16, 2025 am 12:12 AM

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 vs. JavaScript: Community, Libraries, and ResourcesPython vs. JavaScript: Community, Libraries, and ResourcesApr 15, 2025 am 12:16 AM

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.

From C/C   to JavaScript: How It All WorksFrom C/C to JavaScript: How It All WorksApr 14, 2025 am 12:05 AM

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.

JavaScript Engines: Comparing ImplementationsJavaScript Engines: Comparing ImplementationsApr 13, 2025 am 12:05 AM

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.

Beyond the Browser: JavaScript in the Real WorldBeyond the Browser: JavaScript in the Real WorldApr 12, 2025 am 12:06 AM

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.

Building a Multi-Tenant SaaS Application with Next.js (Backend Integration)Building a Multi-Tenant SaaS Application with Next.js (Backend Integration)Apr 11, 2025 am 08:23 AM

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

How to Build a Multi-Tenant SaaS Application with Next.js (Frontend Integration)How to Build a Multi-Tenant SaaS Application with Next.js (Frontend Integration)Apr 11, 2025 am 08:22 AM

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

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

Safe Exam Browser

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 new version

SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows

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.