JS的重载、闭包

重载(overload)

使用重载能减少函数的个数,便于调用者调用和记忆。

重载指的是:相同函数名,不同形参列表的多个函数,在调用时可自动根据传入实参列表的不同,自动选择匹配的函数版本调用。

使用重载的场景:可能根据不同的实参值,执行不同的操作时。

如何使用重载:定义一个包含所有情况的定义的函数,用用arguments对象自动接住函数外部传入的实参值列表。并判断arguments中的实参个数或实参值。

arguments: 每个函数中自带的,专门自动接收所有传入函数的实参值列表的,类数组对象。

当函数执行时,即使不定义形参,也可以随意传入任意多的实参值。不会报错。因为内部都有arguments对象接住所有的实参值

function add(){
  console.log(arguments.length)
};
add(12,1);
//输出结果为2,可以直接打印arguments查看传入的参数,这样可以在函数内部通过判断参数作出相应的操作。

 

闭包(closure)

什么是闭包:即重用一个变量,又保护变量不被篡改的一种机制。

使用闭包的场景:如果希望给一个函数保存一个专属的可重用的变量时,都要用闭包。

为什么要使用闭包:因为全局变量与局部变量都有不可兼得的优缺点,

全局变量: 优: 可重用, 缺: 易被污染

局部变量: 优: 不会被污染, 缺: 不可重用

如何使用闭包:

1. 用外层函数包裹受保护的变量和内层函数对象

2. 外层函数将内层函数的对象返回到外层函数外部

3. 使用者需要调用外层函数,获得返回的内层函数,再起一个名字。

结果: 受保护的变量,不会被全局的语句修改,且被当前内层函数反复使用了。

闭包是怎么形成:外层函数调用后,外层函数的作用域被内层函数引用着,无法释放!

闭包的缺点: 比普通的函数多占用一块内存空间(父母函数的局部变量)

解决: 一旦闭包不再使用,应该立刻释放!将保存内层函数的变量赋值为null,就释放了内层函数对象,同时释放了父母的函数作用域。

function makeAdder(x) {
   return function(y) {
      return x + y;
   };
}

var add5 = makeAdder(5);
var add10 = makeAdder(10);

console.log(add5(2));  // 7
console.log(add10(2)); // 12
/*
在这个示例中,我们定义了 makeAdder(x) 函数,它接受一个参数 x ,并返回一个新的函数。返回的函数接受一个参数 y,并返回x+y的值。

从本质上讲,makeAdder 是一个函数工厂 — 他创建了将指定的值和它的参数相加求和的函数。在上面的示例中,我们使用函数工厂创建了两个新函数 — 一个将其参数和 5 求和,另一个和 10 求和。

add5 和 add10 都是闭包。它们共享相同的函数定义,但是保存了不同的词法环境。在 add5 的环境中,x 为 5。而在 add10 中,x 则为 10。
*/

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值