如何在javascript中异步调用一个函数

JavaScript016

如何在javascript中异步调用一个函数,第1张

function async () {}

setTimeout(function(){

    async()

}, 1000)

上面就是异步调用一个函数。

js里的异步函数有很多, 除了setTimeout和setInterval 还有bind以及很多事件绑定和监听都属于异步操作。

异步处理不用阻塞来等待处理完成,而是允许后续操作,直至其程序将处理完成,并回调通知此函数

那么在js中有如下几种异步方式:

示例1

var async=function(callback){

//read data

setTimeout(function(){

callback('data')

},1000)//1秒后回调

}

//使用

async(function(data){

alert(data)

})

示例2

var async=function(callback){

var xhr=new XMLHttpRequest()

xhr.open('get','.',true)

xhr.onreadystatechange=function(){

callback(xhr.readyStatus)

}

xhr.send()

}

async(function(data){

alert(data)

})

示例3

var async=function(callback){

var img=new Image()

img.onload=img.onerror=function(){

callback(img)

}

img.src='x.jpg'

}

async(function(data){

alert(data)

})