原创

关于js暂停执行的方法

温馨提示:
本文最后更新于 2017年12月22日,已超过 2,462 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我

JavaScript是一门单线程但是可处理异步任务的脚本语言,是没有提供sleep等类似的方法的,当有需求需要暂停js脚本时,可以使用以下的方法  单线程分析:http://blog.csdn.net/talking12391239/article/details/21168489

一:alert,comfirm弹窗暂停

js的alert,confirm弹窗类方法,是可以暂停js脚本执行的

例如:

<script>
console.log(1);
alert(1);
console.log(2);


</script>

仙士可博客

仙士可博客

这样弹窗,是需要点击确认才会执行下面的语句的

就算是定时器也一样暂停

<script>
var i=0;
setInterval(function(){
	console.log(i);
	i++;
	if(i==5){
		alert(i);
	}
},500)
</script>

仙士可博客

仙士可博客

所以,如果需要暂停的话,可以使用弹窗法暂停脚本,缺点是会影响用户体验

二:while();方法暂停

while方法可以暂停,但是会影响浏览器性能,并且不好控制

<script>
var i=0;
console.log(new Date());
while(i<5000000000){
	i++;
}
console.log(new Date());
</script>

仙士可博客

只要控制下while的判断条件,就可以实现暂停了

三,ajax同步请求方法

此方法需要服务器协作才能实现,本人不建议,因为懒,也懒得测试了,

大概步骤就是:ajax同步请求服务器,带上一个参数time,服务器接收之后,sleep(time),到时间再输出,回到ajax回调函数,在这个时间 内,ajax是停止状态的

最后再补充几句,其实js是不能暂停脚本的,上面的方法,只是抢占当前浏览器线程,相当于该线程的某个语句一直还停留在当前浏览器线程,

如:while,当前还未执行完while循环该方法,所以不能退出该线程

不让切换执行,所以实现了暂停

正文到此结束
本文目录