重载(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。
*/