理解JavaScript的定时器与回调机制

定时器方法

JavaScript是单线程的。虽然HTML5已经开始支持异步js了。

JavaScript的setTimeout与setInterval看起来就像已经是多线程的了。但实际上setTimeout与setInterval参数中传入的回调函数,是浏览器执行调用。

例:

setTimeout(function(){
    alert("…")
},1000);

该例中,若1s后,JavaScript引擎正在执行其他函数,则setTimeout中的函数是无法执行的。当JavaScript把其他方法执行完毕,setTimeout中的函数就会被浏览器执行。

同理Ajax的异步回调也是一样的原理。

理解回调方法

综上所述,所谓回调,即方法并不是当前程序调用的,其调用可能来自系统或其他系统。

JavaScript中存在大量回调方法,setTimeout,setInterval,Ajax等回调都是由当前JavaScript解释器调用的。

原文地址:https://www.cnblogs.com/shijiaqi1066/p/3357216.html