html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>windowtitle>
<style>
button{
width: 200px;
height: 50px;
}
style>
<script>
window.onload = () => {
console.log(document.querySelector('.open'));
}
script>
head>
<body>
<button class="open">openbutton>
<button class="close">closebutton>
<script>
console.log(window.document === document);//ture
top = 1;
console.log(top);//指向window本身
document.querySelector('.open').onclick = () => {
open('https://www.baidu.com/','https://www.csdn.net/')
}
document.querySelector('.close').onclick = () => {
close()
}
script>
body>
html>
你把上面的 js代码 window.onload 这个方法去掉你就能看出区别了,你会发现 打印出来的是 null。onload 存在的意义就是等待你页面加载完成,也就是说代码运行到这的时候,并没有直接执行,而是继续往下运行,直到页面加载完成,触发onload ,才会开始打印log。而且打印出来的log 是在你body中的 js 打印之后,不信可以尝试一下哦
onload是页面加载完后,立即执行的方法。所以输出“open”这个标签,是有数据的
确实是自上而下,而且我想不到你说错的原因,就很正常的一个流程...