解决异步的方案---回调函数
栏目: JavaScript · 发布时间: 6年前
内容简介:需要name和age都获取到然后输出。
- 异步没法捕获错误,异步代码不能try catch捕获
- 异步编程中可能出现回调地狱
- 多个异步的操作 在同一个时间内容 同步异步的结果
高阶函数
- 函数作为函数的参数
- 函数执行结果返回函数
after函数(在xxx之后执行,可以限制达到多少次后执行此回调)
function after(times,cb){
return function(){
if(--times==0){
cb()
}
}
}
let fn = after(3,function(){
console.log('达到三次了')
})
fn()
fn()
fn()
复制代码
node文件操作
需要name和age都获取到然后输出。
let fs = require('fs')
let schoolInfo = {}
function after(times,cb){
return function(){
if(--times==0){
cb()
}
}
}
let fn = after(2,function(){
consolr.log(schoolInfo)
})
fs.readFile('./name.txt','utf8',function(err,data){
schoolInfo['name'] = data;
fn()
})
fs.readFile('./age.txt','utf8',function(err,data){
schoolInfo['age'] = data;
fn()
})
复制代码
发布订阅
let dep = {
arr:[],
emit(){
this.arr.forEach(fn=>fn())
}
on(fn){
this.arr.push(fn)
}
}
dep.on(function(){
if(Object.keys(schoolInfo).length===2){
console.log(schoolInfo)
}
})
fs.readFile('./name.txt','utf8',function(err,data){
schoolInfo['name'] = data;
dep.emit()
})
fs.readFile('./age.txt','utf8',function(err,data){
schoolInfo['age'] = data;
dep.emit()
})
复制代码
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- javascript异步中的回调
- Netty推荐addListener回调异步执行
- JavaScript异步之从回调函数到Promise
- JS 异步发展流程(回调函数=>Async/await)
- netty的Future异步回调难理解?手写个带回调异步框架就懂了
- JavaScript 异步编程和回调 – JavaScript 完全手册(2018版)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
HTML5权威指南
[美] Adam Freeman / 谢廷晟、牛化成、刘美英 / 人民邮电出版社 / 2014-1 / 129.00元
《HTML5 权威指南》是系统学习网页设计的权威参考图书。本书分为五部分:第一部分介绍学习本书的预备知识和HTML、CSS 和JavaScript 的最新进展;第二部分讨论HTML 元素,并详细说明了HTML5中新增和修改的元素;第三部分阐述CSS,涵盖了所有控制内容样式的CSS 选择器和属性,并辅以大量代码示例和图示;第四部分介绍DOM,剖析如何用JavaScript 操纵HTML 内容;第五部......一起来看看 《HTML5权威指南》 这本书的介绍吧!