欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺析JavaScript 函數(shù)柯里化

 更新時(shí)間:2020年09月08日 09:16:28   作者:前端開發(fā)  
這篇文章主要介紹了JavaScript 函數(shù)柯里化的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下

柯里化 (Currying)是把接收多個(gè)參數(shù)的原函數(shù)變換成接受一個(gè)單一參數(shù)(原來函數(shù)的第一個(gè)參數(shù)的函數(shù))并返回一個(gè)新的函數(shù),新的函數(shù)能夠接受余下的參數(shù),并返回和原函數(shù)相同的結(jié)果。

ES6的方式實(shí)現(xiàn)柯里化的通用

function currying(fn,...rest1){
	return function(...rest2){
		//這里用apply 是為把數(shù)組形式的參數(shù)直接傳入原函數(shù) null是因?yàn)椴恍枰淖僼his
		return fn.apply(null,rest1.concat(rest2));
	}
}

將一個(gè)sayHello函數(shù)柯里化

function sayHello(name,age,fruit){
	console.log(`我叫${name},我${age}歲了,我喜歡吃${fruit}`);
}

//傳入第一個(gè)參數(shù)
let curryingShowMsg = currying(sayHello,'小明');
//執(zhí)行傳入剩余參數(shù)
curryingShowMsg(22,'芒果');

反柯里化 和柯里化剛好相反。為了讓方法使用場(chǎng)景更廣,使用反柯里化,可以把原生方法借出來,讓任何對(duì)象擁有原生對(duì)象的方法。

二者的區(qū)別

//柯里化
//function(arg1,arg2) => function(arg1)(arg2);
//function(arg1,arg2,...,argn) => function(arg1)(arg2)(...)(argn)
//反柯里化
//obj.func(arg1,arg2) => func(obj,arg1,arg2)

ES6實(shí)現(xiàn)一個(gè)反柯里化

function unCurrying(fn){
	//tar 是我們借給的對(duì)象 以前需要xxx.fn(xx) 現(xiàn)在就可以fn(xxx,xx)
	return function(tar,...argu){
		return fn.apply(tar,argu);
	}
}
//比如我們想把Array.prototype.push方法從原生借出來
let push = unCurrying(Array.prototype.push);
//arrguments是我們借給的對(duì)象
push(arguments,4);

函數(shù)柯里化的高階實(shí)現(xiàn) ,上面的函數(shù)只實(shí)現(xiàn)一層簡(jiǎn)單的柯里化 如果實(shí)現(xiàn)完全的柯里化func(xx)(xx)(xx)(xx)的話,我們要反復(fù)嵌套我們的柯里化函數(shù),這里我們實(shí)現(xiàn)一個(gè)更高階的柯里化通用方法。

function curryingHelper(fn,len){
	//這里先說個(gè)基本知識(shí)點(diǎn) fn.length 返回的是這個(gè)方法需要傳入的參數(shù)個(gè)數(shù)
	//這里第一次運(yùn)行時(shí)通過fn.length 后面遞歸都是用的傳入的len len為剩余的參數(shù)個(gè)數(shù)
	const length = len || fn.length;
	return function(...rest){
		//判斷這次傳入的參數(shù)是否大于等于剩下的參數(shù) 如果不是遞歸返回下一個(gè)方法繼續(xù)傳參
		return rest.length >= length 
		? fn.apply(this,rest)
		: curryingHelper(currying.apply(this,[fn].concat(rest)),length-rest.length)
	}
}
//還是剛才的sayHello 函數(shù)
let betterShowMsg = curryingHelper(sayHello);
//自動(dòng)控制傳參層數(shù)
betterShowMsg('zyx')(22)('葡萄');
betterShowMsg('zyx',22)('葡萄');

柯里化的三種用法

1 參數(shù)的復(fù)用

function Say(name,some){
	console.log(name + '說' + some);
}
//如果我們只想讓zyx說一些東西
let zyxSay = currying(Say,'zyx');
zyxSay('1111');//zyx說1111

2 提高適用性

//通用函數(shù)解決了兼容性的問題,但是同時(shí)在不同場(chǎng)景下,我們可能同一種規(guī)則需要反復(fù)使用
//這就可能會(huì)造成代碼的重復(fù)性 比如

function square(i){ return i*i }//平方
function dubble(i){ return i*2 }//雙倍
function map(handler,list){
	//handle 是操作的規(guī)則 list是操作的arrguments
	return list.map(handler)
}

map(square,[1,2,3]);//數(shù)組每一項(xiàng)平方
map(dubble,[1,2,3]);//數(shù)組每一項(xiàng)加倍
//這就是通用性 我可以用同一個(gè)函數(shù)做很多不同的操作
//但是如果我們需要大量做平方操作 每次我們都需要傳入方法再傳入數(shù)組就造成的代碼浪費(fèi)
//這時(shí)我們通過柯里化提高實(shí)用性

let mapSQ = currying(map,square);//直接定義出來的新的平凡操作函數(shù)
mapSQ([1,2,3]);//以后就不用傳入操作方法了

3 延遲執(zhí)行

let add = function(...rest){
	//定義一個(gè)閉包保存_args
	const _args = [];
	return function cb(...rest){
		if(rest.length == 0){
			//如果不穿參數(shù)了 也就是add() 說明我們需要最后執(zhí)行函數(shù)了
			let res = 0;
			//累加
			console.log(_args);
			for(let data of _args){
				res += data;
			}
			return res;
		}else{
			_args.push(...rest);
			//為了鎖住args 閉包
			return _args;
		}
	}
}()

add(1);
add(2);
let a = add();
console.log(a);//3

以上就是淺析JavaScript 函數(shù)柯里化的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 函數(shù)柯里化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Fetch超時(shí)設(shè)置與終止請(qǐng)求詳解

    Fetch超時(shí)設(shè)置與終止請(qǐng)求詳解

    這篇文章主要給大家介紹了關(guān)于Fetch超時(shí)設(shè)置與終止請(qǐng)求的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Fetch具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • js 實(shí)現(xiàn)菜單左右滾動(dòng)顯示示例介紹

    js 實(shí)現(xiàn)菜單左右滾動(dòng)顯示示例介紹

    菜單左右滾動(dòng)顯示的實(shí)現(xiàn)方法有很多,在本文將為大家介紹下如何使用js實(shí)現(xiàn),需要的朋友可以參考下,希望對(duì)大家有所幫助
    2013-11-11
  • js回調(diào)函數(shù)原理與用法案例分析

    js回調(diào)函數(shù)原理與用法案例分析

    這篇文章主要介紹了js回調(diào)函數(shù)原理與用法,結(jié)合具體案例形式分析了js回調(diào)函數(shù)基本概念、原理、使用方法及操作注意事項(xiàng),需要的朋友可以參考下
    2020-03-03
  • JS Replace 全部替換字符的用法小結(jié)

    JS Replace 全部替換字符的用法小結(jié)

    本篇文章主要是對(duì)JS Replace 全部替換字符的用法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2013-12-12
  • select標(biāo)簽設(shè)置默認(rèn)選中的選項(xiàng)方法

    select標(biāo)簽設(shè)置默認(rèn)選中的選項(xiàng)方法

    下面小編就為大家分享一篇select標(biāo)簽設(shè)置默認(rèn)選中的選項(xiàng)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • JavaScript中通用的jquery動(dòng)畫滾屏實(shí)例

    JavaScript中通用的jquery動(dòng)畫滾屏實(shí)例

    這篇文章主要介紹了JavaScript中通用的jquery動(dòng)畫滾屏實(shí)例,本文通過實(shí)際代碼來詳解實(shí)現(xiàn)方法,需要的朋友可以參考一下
    2022-07-07
  • three.js創(chuàng)造時(shí)空裂縫特效實(shí)現(xiàn)示例

    three.js創(chuàng)造時(shí)空裂縫特效實(shí)現(xiàn)示例

    這篇文章主要為大家介紹了three.js創(chuàng)造時(shí)空裂縫特效實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11
  • 對(duì)于Javascript 執(zhí)行上下文的全面了解

    對(duì)于Javascript 執(zhí)行上下文的全面了解

    下面小編就為大家?guī)硪黄獙?duì)于Javascript 執(zhí)行上下文的全面了解。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • JavaScript中的16進(jìn)制字符(改進(jìn))

    JavaScript中的16進(jìn)制字符(改進(jìn))

    后來經(jīng)過自己的測(cè)試,發(fā)現(xiàn)將字符轉(zhuǎn)換為十六進(jìn)制的方法不完善。
    2011-11-11
  • Bootstrap表單Form全面解析

    Bootstrap表單Form全面解析

    在進(jìn)行自己的后臺(tái)改版時(shí),大體布局都使用了bootstrap,剩下的表單部分沒理由不去使用它,對(duì)于表單的美化和布局,bootstrap做的也是很不錯(cuò)的。下文給大家介紹Bootstrap表單Form全面解析,感興趣的朋友一起看下吧
    2016-06-06

最新評(píng)論