JS对象解构中,用let定义的变量为什么能直接在全局作用域中被使用?(语言-javascript)

刚开始接触ES6+,还在摸索阶段
测试代码:
const P = {
name: 'Job',
age: 68,
fun: function () {
console.log("一个函数");
}
}
let { age, xiaopin } = P;
console.log(age, fun);
console.log(this.age);
输出结果:
68 ƒ () {}
undefined
我的问题:
如果age不是全局作用域里的变量,不是window的一个属性,而是window的一个块中的一个变量。那为什么块级作用域中的变量age可以直接作为全局作用域中的console.log函数的参数?而且还输出了正确的结果?这里的age是保存在哪个对象中?

现在这个 age 相当于是被let声明的 他并不是被保存在对象当中

被let 声明的变量会放置到一个块也就是 Script当中 类似于 node 的 global

但是Script != windows

最外级this指向windows

所以你用this是调不到age的

解构赋值 是新 声明一个age 然后赋值 age=P.age
先 解构 之后赋值 给左边的变量