JavaScript中回调函数与异步的讲解(代码示例)
发表时间:2025-11-09 来源:浏览器大全整理相关软件相关文章人气:
网页的本质就是超级文本标记语言,通过结合使用其他的Web技术(如:脚本语言、公共网关接口、组件等),可以创造出功能强大的网页。因而,超级文本标记语言是万维网(Web)编程的基础,也就是说万维网是建立在超文本基础之上的。超级文本标记语言之所以称为超文本标记语言,是因为文本中包含了所谓“超级链接”点。
本篇文章给大家带来的内容是关于JavaScript中回调函数与异步的讲解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
首先要知道的是,回调和异步不是同一个东西
我以前认为js中每个回调函数都是异步处理的,实际上并不是,可以同步回调,也可以异步回调
callback 例子
说到callback,大家都在javascript中遇到以下的例子
$('#id').on('click', function(){
//code
});
$('#id').setTimeout(function(){
//code
},1000);这些代码用了这么久,知道怎么用,但是可能对回调的概念并不是那么清晰
再来个例子
function a(callback)
{
alert("执行parent函数a!");
alert("开始调用回调函数");
callback();
alert("结束回调函数");
}
function b(){
alert("执行回调函数b");
}
function test()
{
a(b);
a(function() {
alert("执行匿名回调函数");
});
}
test();执行顺序:
执行parent函数a!
开始调用回调函数
执行回调函数b
结束回调函数
执行parent函数a!
开始调用回调函数
执行匿名回调函数
结束回调函数
callback 原理
简单的说,就是把一个函数作为形参进行传递,上面的callback参数可以改为任意名字
callback 用 C++ 实现
不带参数回调
#include <iostream>
using namespace std;
//定义回调函数
void Print()
{
cout <<"Hello World!\n";
}
//定义实现回调函数的"调用函数"
void Call(void (*callback)())
{
callback();
}
//在main函数中实现函数回调
int main(int argc,char* argv[])
{
Call(Print);
return 0;
}带参数回调
#include <iostream>
using namespace std;
//定义带参回调函数
void Print(string s)
{
cout << s << endl;
}
//定义实现带参回调函数的"调用函数"
void Call(void (*callback)(string),string s)
{
callback(s);
}
//在main函数中实现带参的函数回调
int main(int argc,char* argv[])
{
Call(Print,"Hello World!");
return 0;
}异步例子
经典例子
function a(){
console.log('执行a');
setTimeout(function(){
console.log('setTimeout');
}, 1000);
}
function b(){
console.log('执行b');
}
a();
b();执行顺序:
执行a
执行b
setTimeout (一秒后执行)
异步原理
都知道js是单线程的,所谓的单线程就是一次只能完成一个任务,其任务的调度方式就是排队,毫无疑问,这样的效率是不高的,后面的任务必须等到前面的任务执行完毕后才能执行,如果有一个比较耗时的操作,比如ajax请求,文件io
其他语言遇到这种比较耗时的任务往往是开一个线程来处理,但js本身就是单线程的,js对这种任务的处理就是这个一个任务挂载起来,等耗时任务完成后再把回调函数添加到执行队列尾部
所以,在刚刚这个例子中,即使把延迟时间设置为0,也是一样的结果
以上就是JavaScript中回调函数与异步的讲解(代码示例)的详细内容,更多请关注php中文网其它相关文章!
网站建设是一个广义的术语,涵盖了许多不同的技能和学科中所使用的生产和维护的网站。