JavaScript에서 카레 기능을 구현하기 위한 아이디어와 소스 코드

不言
풀어 주다: 2018-11-20 15:22:45
앞으로
2148명이 탐색했습니다.

이 기사는 JavaScript로 카레 기능을 구현하기 위한 아이디어와 소스 코드를 제공합니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.

구현 효과

const curry_fn = curry(fn);
fn(1, 2, 3) == curry_fn(1)(2)(3);
로그인 후 복사

구현 아이디어

  1. 클로저를 통해 들어오는 매개변수 저장

  2. 함수의 길이 속성을 통해 매개변수 개수를 가져옵니다

  3. 매개변수 개수가 부족할 경우 메서드가 직접 반환

  4. 저장된 매개변수의 개수가 원래 함수 매개변수의 개수와 같을 때 원래 함수가 실행됩니다

  5. #🎜🎜 #
#🎜🎜 #
    ES6 매개변수 기본값을 사용하면 길이가 실제 매개변수 개수와 같지 않습니다.
  • The 매개변수는 인수로 얻어지며 ES6은 나머지 매개변수를 직접 사용하여 #🎜🎜 #
  • 소스 코드 구현
function curry(fn) {
    var length = fn.length; //获取原函数的参数个数
    var args = []; // args存储传入参数
    return function curryFn() {
        // 将arguments转换成数组
        var curryArgs = Array.prototype.slice.call(arguments); 
        args = args.concat(curryArgs);
        if (args.length > length) {
            throw new Error('arguments length error')
        }
        // 存储的参数个数等于原函数参数个数时执行原函数
        if (args.length === length) {
            return fn.apply(null, args);
        }
        // 否则继续返回函数
        return curryFn;
    };
}
로그인 후 복사
ES6 버전

function curry(fn) {
    let length = fn.length;
    let args = [];
    return function curryFn(...curryArgs) {
        args = args.concat(curryArgs);
        if (args.length > length) {
            throw new Error('arguments length error')
        }
        if (args.length === length) {
            return fn(...args);
        }
        return curryFn;
    }
}
로그인 후 복사
을 구현합니다.

위 내용은 JavaScript에서 카레 기능을 구현하기 위한 아이디어와 소스 코드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:segmentfault.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!