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_!  阅读(133)  评论(0编辑  收藏  举报
编辑推荐:
· 智能桌面机器人:用.NET IoT库控制舵机并多方法播放表情
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
阅读排行:
· DeepSeek火爆全网,官网宕机?本地部署一个随便玩「LLM探索」
· 【译】.NET 升级助手现在支持升级到集中式包管理
· 开发者新选择:用DeepSeek实现Cursor级智能编程的免费方案
· 独立开发经验谈:如何通过 Docker 让潜在客户快速体验你的系统
· 并发编程 - 线程同步(二)
点击右上角即可分享
微信分享提示