作用域 闭包 作用域链

7 篇文章 0 订阅

闭包

闭包 函数内部返回一个新的函数
1.函数作为另一个函数的返回值
var a = 200;
function fn1(){//0x0001
var a = 1;
return function (){//0x0002
console.log(a);//1
}
}
var fn = fn1(); //0x0002
fn();//–>1

2.函数作为参数被传递
function fnc1(fnc){
    let a = 200;
    fnc()
}
function fnc(){
    console.log(a)
}
fnc1(fnc);

闭包的有优缺点

优点
(一)变量长期驻扎在内存中
(二)另一个就是可以重复使用变量,并且不会造成变量污染
缺点
由于闭包会使得函数中的变量都被保存在内存中,内存消耗很大,所以不能滥用闭包,否则会造成网页的性能问题,在IE中可能导致内存泄露。解决方法是,在退出函数之前,将不使用的局部变量全部删除。

作用域

1 全局 局部(函数) 块级
全局作用域
函数作用域 函数在执行的时候会产生一个独立作用域
块级作用域 ES新增的 ==>{}

作用域链

function内部存在预解释
自由变量: 当前作用域没有定义的变量
function的预解释优先级高于var出来的变量
自由变量的向上级作用域一层一层的查找,直到找到最高层全局作用域,这种机制 就是作用域链
var x = 30;
function test() { //x fn x
function x() {
}
alert(x); // fn x
var x = 10;
alert(x); //10
x = 20;
alert(x);//20 }
test();
作用域链==>自由变量的向上级作用域一层一层的查找,直到找到最高层全局作用域
自由变量==>a
var a = 10;
function x(){
console.log(a);
(function(){ console.log(a);//10
console.log(b);//undefined
})()
}
x()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值