JavaScript 闭包

不严格的说闭包就是函数,直接上例子

 

复制代码
let f;
{
    let o = { note:"Safe"};
    f = function(){
        return o;
    }
}
let oRef = f();
oRef.note = "UnSafe Any More"
复制代码

 

在块的外部依然可以访问到内部变量o,那么这个块(包括父作用域)构成了一个闭包,不管在任何地方调用oRef,他都有权限访问块中的变量o。

 

 

即时调用函数表达式:IIFE,使用函数内部数据,确保安全性,可返回任意类型(数组,对象,函数)

const massage = (function(){
    const secret = "Im a secret";
    return `the secret is ${secret.length} characters long.`
})();
console.log(massage);

secret因为在函数中,函数外是无法访问的.

 

提升机制:

1 变量的提升

x;
let x = 4;//会报错

x;//undefined
var x = 4;
x;//4

在以上的例子中可以看到使用var定义的话会把该变量的声明提升至该作用域的顶部。(不是提升赋值)

 

var可重复赋值,let和const不可以。let可完全取代var

 

2 函数的提升:

f();
function f(){
    console.log('f');
}

在第一行f()也会执行打印‘f’。

f();
let f =function(){
    console.log('f');
}

此时在第一行f()就会报错。在let之前就是该变量的“临时死区”(TDZ)

posted @   KeepLearning_!  阅读(132)  评论(0编辑  收藏  举报
编辑推荐:
· 智能桌面机器人:用.NET IoT库控制舵机并多方法播放表情
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
阅读排行:
· 新年开篇:在本地部署DeepSeek大模型实现联网增强的AI应用
· DeepSeek火爆全网,官网宕机?本地部署一个随便玩「LLM探索」
· Janus Pro:DeepSeek 开源革新,多模态 AI 的未来
· 上周热点回顾(1.20-1.26)
· 【译】.NET 升级助手现在支持升级到集中式包管理
点击右上角即可分享
微信分享提示