ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript関数のカリー化の詳細説明

JavaScript関数のカリー化の詳細説明

PHP中文网
リリース: 2017-04-01 15:08:01
オリジナル
2188 人が閲覧しました

カリー化とは

カリー化とは、複数のパラメータを受け取る関数を、単一のパラメータを受け入れる関数に変換する変換処理ですパラメータ (注釈: 元の関数の最初のパラメータ) 他のパラメータが必要な場合は、残りのパラメータを受け入れて結果を返す新しい関数を返します。

Ke Lihua 関数のアイデア: js の前処理のアイデア。破棄されないスコープを形成するために関数の実行を使用するという原則。 , 前処理が必要な、破棄されていないすべてのコンテンツをこのスコープに格納し、小さな関数を返します。ここからは、小さな関数で、以前に格納したものに対して関連する操作を実行できます。値;

カリー化関数は主に前処理の役割を果たします。

バインド メソッドの役割: Passコールバック メソッド内のこれはコンテキストとして前処理されます。

バインド メソッドの実装原則 1 コードは次のとおりです。 > 次のコード部分は、プロトタイプ チェーンのバインディング実装原則を模倣しています。

/**
* bind方法实现原理1
* @param callback [Function] 回调函数
* @param context [Object] 上下文
* @returns {Function} 改变this指向的函数
*/
function bind(callback,context) {
var outerArg = Array.prototype.slice.call(arguments,2);
// 表示取当前作用域中传的参数中除了fn,context以外后面的参数;
return function (){
var innerArg = Array.prototype.slice.call(arguments,0);//表示取当前作用域中所有的arguments参数;
callback.apply(context,outerArg.concat(innerArg));
}
}
ログイン後にコピー

関数カリー化 (Currying)

/**
* 模仿在原型链上的bind实现原理(柯理化函数思想)
* @param context [Object] 上下文
* @returns {Function} 改变this指向的函数
*/
Function.prototype.mybind = function mybind (context) {
var _this = this;
var outArg = Array.prototype.slice.call(arguments,1);
// 兼容情况下
if('bind' in Function.prototype) {
return this.bind.apply(this,[context].concat(outArg));
}
// 不兼容情况下
return function () {
var inArg = Array.prototype.slice.call(arguments,0);
inArg.length === 0?inArg[inArg.length]=window.event:null;
var arg = outArg.concat(inArg);
_this.apply(context,arg);
}
}
ログイン後にコピー

コンピューター サイエンスにおけるカリー化とは、複数のパラメーターを受け入れる関数を 1 つのパラメーター (元の関数の最初のパラメーター) を受け入れる関数に変換し、残りのパラメーターを受け入れて結果を返す新しい関数を返す手法です カリー化とは、事前に特定のパラメーターを渡して単純な関数を取得することです。ただし、事前に渡されたパラメータはクロージャに保存されるため、いくつかの独特の特徴があります。例:

例:

上記は JavaScript 関数のカリー化の詳細な説明です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) を参照してください。 )!

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート