JavaScript의 고차 함수 및 커링

WBOY
풀어 주다: 2023-09-04 17:57:07
앞으로
761명이 탐색했습니다.

JavaScript 中的高阶函数和柯里化

함수는 모든 프로그래밍 언어에서 매우 유용한 기능입니다. 개발자는 이 기능이 포함되지 않은 프로그래밍 언어를 찾을 수 있습니다. 게다가 프로그래밍 언어를 배우기 시작할 때 우리는 코드의 재사용성을 제공하는 코드 블록과 같은 기능에 대해 확실히 배웁니다.

이 튜토리얼에서는 고차 함수와 커링에 대해 알아봅니다.

고차 함수

자바스크립트 커링을 시작하기 전에 먼저 고차 함수를 이해해 봅시다.

고차 함수의 간단한 정의는 다른 함수를 매개변수로 사용하거나 함수를 반환하는 함수입니다. JavaScript나 C++, Python과 같은 다른 프로그래밍 언어에서 sort() 메서드를 사용해 본 적이 있나요? 그렇다면 콜백 함수를 sort() 메서드에 인수로 전달하여 특정 컨텍스트에 따라 배열을 정렬했을 수 있습니다.

따라서 sort() 메서드는 고차 함수라고 말할 수 있습니다.

문법

사용자는 다음 구문에 따라 고차 함수를 사용할 수 있습니다.

으아아아

위 구문에서 sort()sortArray() 함수를 매개변수로 전달했기 때문에 고차 함수입니다.

아래 예에서는 다양한 숫자 값을 포함하는 숫자 배열을 만들었습니다. 그런 다음 filter() 메서드를 사용하여 배열에서 2로 나눌 수 있는 모든 요소를 ​​필터링합니다.

사용자는 filter_func() 함수를 filter() 메소드의 매개변수로 전달했음을 확인할 수 있습니다. 따라서 filter() 메서드는 고차 함수라고 말할 수 있습니다.

으아아아

이 예에서는 문자열 배열을 만들었습니다. 그 후 map() 메소드를 사용하여 모든 배열 값의 첫 글자를 대문자로 표시합니다. 콜백 화살표 함수를 map 메소드에 인수로 전달합니다. map 메소드는 첫 번째 문자를 대문자로 바꾼 후 문자열을 반환합니다.

substr()toUpperCase() 메소드를 사용하여 각 배열 문자열의 첫 번째 문자를 대문자로 표시합니다.

으아아아

이제 사용자는 고차 함수 사용의 이점을 알 수 있습니다. 예를 들어, filter() 메서드는 JavaScript의 배열 라이브러리에 구현되어 사용자가 사용자 정의 콜백 함수를 매개변수로 전달하여 필터 논리를 재정의할 수 있습니다.

JavaScript로 커링하기

Currying은 고차 함수와 유사하며 함수를 반환합니다. 커리 함수는 여러 매개변수를 허용하며 사용자는 매개변수 값을 중첩 함수에 전달할 수 있습니다.

커리 함수의 마지막 중첩 함수는 최종 출력을 반환합니다.

문법

사용자는 다음 구문에 따라 카레 함수를 작성할 수 있습니다.

으아아아

위 구문의 addition() 함수에서 이 함수를 반환합니다. 또한 사용자는 여러 매개변수를 전달하여 addition() 함수를 호출하는 방법을 관찰할 수도 있습니다.

아래 예에서는 addition()이라는 카레 함수를 만듭니다. 덧셈 함수에는 매개변수가 하나만 있습니다. 또한 단일 인수를 사용하는 중첩 함수를 반환합니다. 중첩 함수는 num1num2 인수의 합계를 반환합니다.

으아아아

사용자는 이 튜토리얼에서 고차 기능과 카레 기능에 대해 배웠습니다. 고차 curred 함수에는 다양한 용도가 있으며 그 중 일부는 세 가지 예에서 살펴보았습니다.

위 내용은 JavaScript의 고차 함수 및 커링의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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