javascript - 为什么从dom中把script标签移除了,还可以执行下面的代码?
本文介绍了javascript - 为什么从dom中把script标签移除了,还可以执行下面的代码?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
</head>
<body>
<script type="text/javascript">
var src=document.querySelector("script");
document.body.removeChild(src);
alert(1);
</script>
</body>
</html>
如上代码,dom中已经没了这个script标签 ,为什么下面代码alert(1)
还在执行?
解决方案
楼主这个题目提得非常好,我刚花了一段时间google一下才搞懂,之前还误会了楼主的意思真是抱歉。
原因其实也就是js的按块执行、非阻塞I/O以及Event loop机制。JavaScript代码块被执行,创造出自己的执行环境后,就完全和dom中的script
标签脱离了。事件队列中的事件全都执行完毕后执行环境才被销毁。
Removed JavaScript is still executable
The JavaScript Event Loop: Explained
Concurrency model and Event Loop
这篇关于javascript - 为什么从dom中把script标签移除了,还可以执行下面的代码?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文