> 웹 프론트엔드 > JS 튜토리얼 > HOF(고차 함수)에 대한 자세한 설명입니다.

HOF(고차 함수)에 대한 자세한 설명입니다.

WBOY
풀어 주다: 2024-08-29 12:37:43
원래의
1281명이 탐색했습니다.

Higher-Order Functions (HOFs) সম্পর্কে বিস্তারিত আলোচনা

HOF(고차 함수)는 다른 함수를 인수로 받거나 함수를 반환하거나 둘 다를 수행할 수 있는 함수입니다. JavaScript의 함수는 일류 시민으로 간주됩니다. 즉, 함수를 변수로 저장하고 인수로 전달하고 반환할 수 있습니다. 이 때문에 자바스크립트에서는 고차 함수를 만드는 것이 쉽습니다.

고차 함수는 다음과 같은 함수입니다.

  1. 하나 이상의 기능을 입력으로 사용할 수 있습니다.
  2. 함수를 출력으로 반환할 수 있습니다.

이러한 기능은 프로그래밍을 더욱 모듈화하고 재사용 가능하게 만드는 데 도움이 됩니다.

예:-

function higherOrderFunction(callback) {
    // কিছু কাজ করল
    console.log("Executing the callback function now...");
    callback();  // কলব্যাক ফাংশনকে কল করা হচ্ছে
}

function sayHello() {
    console.log("Hello, World!");
}

// higherOrderFunction কে একটি ফাংশন হিসেবে call করা হল
higherOrderFunction(sayHello); 
// Output:
// Executing the callback function now...
// Hello, World!
로그인 후 복사

위 예에서 lowerOrderFunction은 sayHello라는 함수를 인수로 받아 호출하는 고차 함수입니다.

고차 함수의 장점:

  1. 코드 재사용성: HOF를 사용하면 공통 기능을 재사용할 수 있습니다.
  2. 추상화: HOF는 복잡한 논리를 추상화하여 단순화합니다.
  3. 모듈화: 코드를 더 작은 부분으로 나누면 관리가 더 쉬워집니다.
  4. 함수형 프로그래밍: HOF는 함수형 프로그래밍의 기초이며, 함수에는 상태나 변경 가능한 데이터가 포함되어 있지 않습니다.

고차 함수 사용:

  • 이벤트 핸들러: HOF는 특정 이벤트 후에 수행할 작업을 정의하는 이벤트 핸들러로 자주 사용됩니다.
  • 비동기 프로그래밍: AJAX 호출과 같은 비동기 작업에서 AJAX 호출 후에 수행할 작업은 HOF에 의해 결정됩니다.
  • 커링: 커링은 함수를 분해하고 부분 인수를 사용하여 새 함수를 만듭니다.
  • 구성: HOF는 작은 기능을 결합하여 복잡한 기능을 형성하는 데 사용할 수 있습니다.

JavaScript의 일반적인 고차 함수

JavaScript에는 일반적으로 배열 작업에 사용되는 다양한 고차 함수가 내장되어 있습니다. 몇 가지 일반적인 HOF는 다음과 같습니다.

  1. map(): 배열의 각 요소에 지정된 함수를 적용하고 새 배열을 반환합니다.

    javascriptCopy code
    const numbers = [1, 2, 3, 4];
    const doubled = numbers.map(function(num) {
        return num * 2;
    });
    console.log(doubled); // Output: [2, 4, 6, 8]
    
    
    로그인 후 복사
  2. filter(): এটি একটি array-এর উপাদানগুলোকে একটি নির্দিষ্ট condition-এর ভিত্তিতে ফিল্টার করে এবং একটি নতুন array রিটার্ন করে।

    javascriptCopy code
    const ages = [18, 21, 16, 25, 30];
    const adults = ages.filter(function(age) {
        return age >= 18;
    });
    console.log(adults); // Output: [18, 21, 25, 30]
    
    
    로그인 후 복사
  3. reduce(): এটি একটি array-কে একটি single value-তে রিডিউস করে, একটি accumulator ব্যবহার করে।

    javascriptCopy code
    const numbers = [1, 2, 3, 4];
    const sum = numbers.reduce(function(acc, num) {
        return acc + num;
    }, 0);
    console.log(sum); // Output: 10
    
    로그인 후 복사
  4. forEach(): এটি একটি array-এর প্রতিটি উপাদানে নির্দিষ্ট ফাংশন অ্যাপ্লাই করে, কিন্তু কোনো নতুন array রিটার্ন করে না।

    javascriptCopy code
    const numbers = [1, 2, 3];
    numbers.forEach(function(num) {
        console.log(num * 2); // Output: 2, 4, 6
    });
    
    로그인 후 복사
  5. Function Returning Function : JavaScript-এ, ফাংশন Higher-Order Functions এর মাধ্যমে অন্য একটি ফাংশনকে রিটার্ন করতে পারে। এটি শক্তিশালী কৌশল যেমন currying এবং function composition করতে সক্ষম করে।

javascriptCopy code
function createMultiplier(multiplier) {
    return function(number) {
        return number * multiplier;
    };
}

const double = createMultiplier(2);
const triple = createMultiplier(3);

console.log(double(5)); // Output: 10
console.log(triple(5)); // Output: 15
로그인 후 복사

এই উদাহরণে, createMultiplier একটি Higher-Order Function যা একটি ফাংশনকে রিটার্ন করে যা একটি সংখ্যাকে গুণ করবে নির্দিষ্ট multiplier দিয়ে।

  1. Callback Functions : Callback Functions হল একটি ফাংশন যা একটি অন্য ফাংশনের আর্গুমেন্ট হিসেবে পাস করা হয় এবং প্রয়োজন অনুযায়ী সেই ফাংশনের ভিতরে এক্সিকিউট করা হয়। Callback Functions মূলত Higher-Order Functions এর একটি বিশেষ রূপ।
javascriptCopy code
function fetchData(callback) {
    setTimeout(function() {
        callback("Data fetched successfully!");
    }, 1000);
}

fetchData(function(message) {
    console.log(message); // Output: "Data fetched successfully!"
});
로그인 후 복사

এই উদাহরণে, fetchData একটি HOF, যা একটি ফাংশনকে আর্গুমেন্ট হিসেবে নেয় এবং সেটাকে নির্দিষ্ট সময় পরে কলব্যাক হিসেবে কল করে।

Conclusion

Higher-Order Functions JavaScript-এ একটি শক্তিশালী এবং বহুমুখী কনসেপ্ট যা কোডকে আরও সংগঠিত, পুনঃব্যবহারযোগ্য, এবং পরিষ্কার করে তোলে। ফাংশনকে ফার্স্ট-ক্লাস সিটিজেন হিসেবে গ্রহণ করে, JavaScript ডেভেলপারদের বিভিন্ন প্রোগ্রামিং প্যাটার্ন অনুসরণ করতে দেয়, যা ডেভেলপমেন্টকে আরও কার্যকর করে তোলে।

위 내용은 HOF(고차 함수)에 대한 자세한 설명입니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿