闭包的一点功能

本文深入探讨了JavaScript中的闭包现象,包括如何在函数外部访问局部变量、保持局部变量的存活状态以避免垃圾回收,以及闭包中的`this`指向问题。通过示例展示了闭包在内存管理和函数作用域中的关键作用,同时对比了常规函数与箭头函数中`this`的差异。

1,在函数外部获取局部变量

function test(){
    var a = 100
    function test2(){
      console.log(a)
    }
      return test2
 }
 test()()//100

2,让局部变量始终生存在内存当中,避免被垃圾回收机制回收

function fun(){
  var num = 1000
  nAdd = function(){num+=1}
  return function(){
    console.log(num)
  }
}
var result = fun()
result()//1000
nAdd()//1001
result()//1001

3,关注点:闭包中的this,大部分指向的都是window

var theName =  'outside'
var testObj = {
  theName:'inside',
  getNameFun:function(){
    return function(){
      console.log(this.theName)
    }
  }
}
testObj.getNameFun()()//outside

但是由于箭头函数的this指向是跟着父级走的,那么
var theName =  'outside'
var testObj = {
  theName:'inside',
  getNameFun:function(){
    return ()=>{
      console.log(this.theName)
    }
  }
}
testObj.getNameFun()()//inside

这里getNameFun的父级是testObj 这个对象,这里的this指向对象内部,打印结果为inside

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值