時間:2019/11/3
4).高階函數(shù)(對其他函數(shù)進行操作的函數(shù)揭芍,它接收函數(shù)作為參數(shù)或將函數(shù)作為返回值輸出)
5).閉包(一個作用域可以訪問另一個函數(shù)的局部變量,該局部變量所在的函數(shù)形成閉包)
兩種形式:一個函數(shù)使用另一個函數(shù)中的局部變量或在全局使用函數(shù)中的局部變量造虎;
// 閉包主要作用:延長變量的作用范圍
1.
function fn() {
var num = 10;
return function() {
console.log(num);
}
}
var f = fn();
f(); // 10
2.
function fn() {
var num = 10;
return function() {
console.log(num);
num++;
}
}
var f = fn(); // 創(chuàng)建了fn的引用f,使得fn執(zhí)行完后num變量沒有被立即銷毀,容易造成內(nèi)存泄漏伞芹,需手動釋放引用(引用賦值為null)
f(); // 10
f(); // 11
f(); // 12
f = null;
var f = fn();
f(); // 10
總結.jpg
6).遞歸
1.遞歸函數(shù)(一個函數(shù)在內(nèi)部可以調(diào)用其本身)栈雳,遞歸中必須加退出條件(return)护奈。
案例:
1.遞歸求1~n的階乘;
2.遞歸求斐波那契數(shù)列哥纫;
3.遞歸遍歷多層Json格式數(shù)據(jù)霉旗。
2.深拷貝和淺拷貝
1).淺拷貝只是拷貝一層(簡單數(shù)據(jù)類型),更深層次對象級別的只拷貝引用(復雜數(shù)據(jù)類型拷貝地址)蛀骇;
2).深拷貝拷貝多層厌秒,每一級別的數(shù)據(jù)都會拷貝;
3).Object.assign(target, ...sources) ES6新增方法實現(xiàn)淺拷貝
4).封裝函數(shù)實現(xiàn)深拷貝