把使用多個引數的函式轉換成一系列使用乙個引數的函式,返回接受餘下引數並且返回結果的新函式;(也就是:只傳遞乙個部分引數來呼叫這個函式,讓他返回乙個新函式去處理餘下的引數)
日常應用
動態建立函式:(dom元素新增事件監聽是,根據相容性判斷生成不同的函式)
//只在函式第一次執行時判斷一次,用到了閉包和立即執行函式
const addevent =
(function()
}else
if(window.attachevent)}}
)()
延遲計算:(呼叫方法傳入引數,不計算最後結果,當不傳任何值以後再計算)
const
adds
=function
(...args))}
function
currying2
(func)
else}}
let sum2 =
currying2
(adds)
;let addcurrytwo =
sum2(1
,2)(
3);addcurrytwo(2
)();
// 8
延時計算(指定傳入的引數數量,滿足後執行計算)
function
currying1
(fn, length)
else}}
// 計算方法
const fn =
currying1
(function
(a, b, c));
fn("a",
"b")
("c"
)// ["a", "b", "c"]fn(
"a")
("b")(
"c")
// ["a", "b", "c"]fn(
"a")
("b"
,"c"
)// ["a", "b", "c"]
引數復用
判讀乙個資料的型別
function
istype
(type)
}var res =
istype
('string')(
null
);
呼叫tostring可以獲取每個物件的型別,但是不同的物件有不同的tostring的實現,所以要呼叫object.prototype.tostring()方法。
可以通過bind方法擴充套件,通過引數復用,實現乙個tostr方法:
//使用函式的call方法指定乙個this值,然後bind返回乙個新函式,始終將object.prototype.tostring作為傳入的引數
const
tostr
= function.prototype.call.
bind
(object.prototype.tostring)
;tostr([
1,2,
3]);
//'[object array]'
bind方法
var value =2;
var foo =
;function
bar(name,age)
}var bindfoo = bar.
bind
(foo,
'tommy').
bind
(foo,23)
;console.
log(
bindfoo()
)//
函式柯里化
在電腦科學中,柯里化 currying 是把接受多個引數的函式變換成接受乙個單一引數 最初函式的第乙個引數 的函式,並且返回接受餘下的引數且返回結果的新函式的技術。在直覺上,柯里化聲稱 如果你固定某些引數,你將得到接受餘下引數的乙個函式 柯里化實現的原理 在函式式程式語言中,將函式可以當做物件傳遞呼...
函式柯里化
curry 的概念 只傳遞給函式一部分引數來呼叫它,讓它返回乙個函式去處理剩下的引數先看乙個簡單例子,add函式接受 2 個引數 或者多個 addx函式接受 1 個引數。換而言之,所謂 柯里化 就是把乙個多引數的函式,轉化為單引數函式。將乙個函式轉換為乙個新的函式 非柯里化 function add...
函式柯里化
curry 的概念 只傳遞給函式一部分引數來呼叫它,讓它返回乙個函式去處理剩下的引數先看乙個簡單例子,add函式接受 2 個引數 或者多個 addx函式接受 1 個引數。換而言之,所謂 柯里化 就是把乙個多引數的函式,轉化為單引數函式。將乙個函式轉換為乙個新的函式 非柯里化 function add...