一喘鸟、純函數(shù)
特點(diǎn):
- 對(duì)于相同的輸入,永遠(yuǎn)會(huì)得到相同的輸出藤乙。
- 沒(méi)有任何可觀察的副作用
- 不依賴外部環(huán)境的狀態(tài)
例子:
//Array.slice是純函數(shù),Array.splice不是純函數(shù)麸澜,存在副作用
var arr = [1,2,3,4,5];
arr.slice(0,3);
arr.splice(0,3);
優(yōu)點(diǎn):
- 降低系統(tǒng)復(fù)雜性
- 可緩存
var min = 18;
//checkAge不是純函數(shù),因?yàn)槠湟蕾囃獠孔兞縨in奏黑。
var checkAge1 = age=> age>min;
//雖然checkAge2是純函數(shù)炊邦,但缺乏擴(kuò)展性
var checkAge2 = age=>age>18;
二、函數(shù)柯理化
特點(diǎn):傳遞函數(shù)的一部分參數(shù)來(lái)調(diào)用熟史,返回一個(gè)函數(shù)去處理剩下的參數(shù)馁害。
例子一:改寫剛才的checkAge函數(shù),使其具備可擴(kuò)展性
var checkAge = min=>(age=>age>min);
//通過(guò)傳入?yún)?shù)18蹂匹,將min變量固定下來(lái)碘菜,提高擴(kuò)展性。
var checkAge18 = checkAge(18);
//純函數(shù),剛剛的忍啸!
checkAge18(20); //true;
例子二:函數(shù)柯理化過(guò)程
//柯理化之前
function add(x,y){
return x+y;
}
//柯理化之后
function addX(y){
return function(x){
return x+y;
}
}
addX(2)(1); //3
例子三:通過(guò)函數(shù)柯理化來(lái)“緩存”參數(shù)
function test(p1,p2){
this.val = p1+p2;
}
var bar = test.bind(null,"p1");
var baz = new bar("p2");
console.log(baz.val); //p1p2
優(yōu)點(diǎn):
- “預(yù)加載”函數(shù)的方法
- 避免純函數(shù)的硬編碼仰坦,提高可擴(kuò)展性
- 降低純函數(shù)對(duì)外部變量的依賴
三、函數(shù)組合
特點(diǎn):有效解決函數(shù)嵌套的問(wèn)題h(g(f(x)))
const compose = (f,g)=>( x=>f(g(x)));
var first = arr=>arr[0];
var reverse = arr=>arr.reverse();
var last = compose(first,reverse);
last([0,1,2,3,4,5]); //5
四吊骤、Point Free
把對(duì)象自帶的方法轉(zhuǎn)換成純函數(shù)缎岗,不要命名中間轉(zhuǎn)瞬即逝的變量静尼。
Bad Case:
const f = str=>str.toUpperCase().split(' ');
Good Case:
const compose = (f,g)=>( x=>f(g(x)));
var toUpperCase = word=> word.toUpperCase();
var split = x=>(str=>str.split(x));
var f = compose(split(' '), toUpperCase);
f('abcd efgh'); //['ABCD','EFGH']
優(yōu)點(diǎn):減少不必要的命名白粉,讓代碼保持簡(jiǎn)潔、通用
五鼠渺、聲明式與命令式代碼
//命令式
var CEOs = [];
for( var i=0; i<companies.length; ++i ){
CEOs.push(compaines[i].CEO);
}
//聲明式
let CEOs = companies.map(c=>c.CEO);
優(yōu)點(diǎn):
- 專注于編寫業(yè)務(wù)代碼鸭巴,不需要考慮內(nèi)部實(shí)現(xiàn)。
- 優(yōu)化代碼時(shí)拦盹,只需要集中目光在函數(shù)內(nèi)部即可鹃祖。
六、惰性求值