热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

JavaScript中回调函数与异步的讲解(code)

web前端|js教程c++,javascriptweb前端-js教程本篇文章给大家带来的内容是关于JavaScript中回调函数与异步的讲解(代码示例),有一定的参考价值,有需要的

web前端|js教程Javascript中回调函数与异步的讲解(code)
c++,Javascript
web前端-js教程
本篇文章给大家带来的内容是关于Javascript中回调函数与异步的讲解(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
android侧边栏源码,vscode 引用提示,ubuntu 5.04,实时检测tomcat,sqlite怎么导出db,优惠券发布插件,适合后端的前端框架2019,如何清除鱼缸内爬虫,php 运行命令,微信seo规则,网站本地环境搭建教程,什么是网页轮播图,网站后台上传模板lzw
首先要知道的是,回调和异步不是同一个东西
我以前认为js中每个回调函数都是异步处理的,实际上并不是,可以同步回调,也可以异步回调
引擎源码 假人,vscode代码对比,ubuntu grant,拦截tomcat url,怎么查询所有表sqlite,dz 整合插件,框架前端快速开发排名网站,爬虫类动物进化,php 中文手册chm,seo属于什么单位,asp.net网站验证码下载,淘宝客php网页模板,手机模板怎么编辑lzw
callback 例子
图列表网站源码,ubuntu正常安装软件,tomcat内存占用过高,pytv爬虫教学,php循环优化,武隆区智能化seo推广包含什么lzw
说到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 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 using namespace std; //定义带参回调函数void Print(string s) { cout <

异步例子

经典例子

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,也是一样的结果


推荐阅读
author-avatar
男孩形式恋人
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有