ホームページ > 記事 > ウェブフロントエンド > JavaScript関数のカリー化の詳細説明
カリー化とは
カリー化とは、複数のパラメータを受け取る関数を、単一のパラメータを受け入れる関数に変換する変換処理ですパラメータ (注釈: 元の関数の最初のパラメータ) 他のパラメータが必要な場合は、残りのパラメータを受け入れて結果を返す新しい関数を返します。
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) を参照してください。 )!