Async Functions এর ধারণা

Async/Await - জাভাস্ক্রিপ্ট ইএস৬ (ES6) - Web Development

286

Async Functions ES6 (ECMAScript 2015) এ একটি নতুন ফিচার, যা অ্যাসিঙ্ক্রোনাস কোড লেখা এবং পরিচালনা করা সহজ করে তোলে। async এবং await কিওয়ার্ড ব্যবহার করে আপনি অ্যাসিঙ্ক্রোনাস অপারেশনগুলোকে সিঙ্ক্রোনাস ফাংশনের মতো দেখতে এবং লিখতে পারবেন, যা কোডের রিডেবিলিটি এবং ডিবাগিং প্রক্রিয়া অনেক সহজ করে তোলে।


Async Functions কী?

async ফাংশন হলো এমন একটি ফাংশন, যা অ্যাসিঙ্ক্রোনাস কাজ (যেমন, নেটওয়ার্ক কল, টাইমআউট, ডেটাবেস অপারেশন) সম্পাদন করতে সক্ষম। async ফাংশনটি সরাসরি একটি Promise রিটার্ন করে এবং এর মধ্যে await কিওয়ার্ড ব্যবহার করে প্রমিজের রেজাল্ট অ্যাক্সেস করা হয়।


Async Functions এর ব্যবহার

  1. Async Function Declaration: আপনি যখন একটি ফাংশনকে async হিসেবে ডিফাইন করবেন, তখন তা একটি Promise রিটার্ন করবে।

    উদাহরণ:

    async function fetchData() {
      return "Data fetched successfully!";
    }
    
    fetchData().then(result => console.log(result));  // "Data fetched successfully!"
    

    এখানে, fetchData() ফাংশনটি async হওয়ায় এটি একটি Promise রিটার্ন করেছে, এবং তার পরে then() ব্যবহার করে প্রমিজের রেজাল্ট পাওয়া গেছে।


Await কিওয়ার্ড

await কিওয়ার্ডটি শুধু async ফাংশনের মধ্যে ব্যবহার করা যেতে পারে এবং এটি Promise এর রেজাল্টের জন্য অপেক্ষা করে। এটি একটি প্রমিজের রেজাল্ট পাওয়ার পরবর্তী লাইন কার্যকর হতে দেয়। await ব্যবহারের মাধ্যমে অ্যাসিঙ্ক্রোনাস কোডকে সিঙ্ক্রোনাস কোডের মতো দেখতে এবং লেখতে পারবেন।

উদাহরণ:

async function fetchData() {
  let result = await fetch('https://api.example.com/data');
  let data = await result.json();
  return data;
}

fetchData().then(data => console.log(data));  // রিটার্নড ডেটা এখানে প্রদর্শিত হবে

এখানে, await fetch(...) দিয়ে প্রমিজটি রেজাল্ট পাওয়ার জন্য অপেক্ষা করা হচ্ছে, এবং তার পরের await result.json() স্টেটমেন্টটি ডেটা ফরম্যাটে রূপান্তর করে।


Async Functions এর সুবিধা

  1. সিঙ্ক্রোনাস কোডের মতো অ্যাসিঙ্ক্রোনাস কোড লেখা: async এবং await কিওয়ার্ড ব্যবহার করে অ্যাসিঙ্ক্রোনাস কোডকে সিঙ্ক্রোনাস কোডের মতো দেখতে এবং লিখতে পারবেন। এতে কোড পড়া এবং ডিবাগ করা অনেক সহজ হয়, কারণ আপনি বারবার .then() বা .catch() ব্যবহার করতে হয় না।
  2. এস্যাঙ্ক্রোনাস অপারেশনগুলোকে সহজে পরিচালনা করা: যখন আপনি অ্যাসিঙ্ক্রোনাস কাজগুলোর জন্য await ব্যবহার করেন, তখন কোড একটানা চলতে থাকে, যেমন কোনো দীর্ঘ সময় নেয়ার কাজ সম্পন্ন না হওয়া পর্যন্ত পরবর্তী কোড লাইন এক্সিকিউট হয় না। এটি কোডের সঠিক অর্ডার মেনে চলতে সাহায্য করে।
  3. প্রমিজের সাথে সমন্বয়: async ফাংশন প্রমিজ রিটার্ন করে, তাই আপনি সহজেই প্রমিজের then(), catch(), এবং finally() ব্যবহার করতে পারেন। এটি প্রমিজের ব্যবস্থাপনা আরও শক্তিশালী এবং কার্যকর করে তোলে।

Error Handling with Async/Await

এ্যাসিঙ্ক্রোনাস কোডে ভুল হওয়া অত্যন্ত সাধারণ, তবে async এবং await এর মাধ্যমে try...catch ব্লক ব্যবহার করে সহজে এরর হ্যান্ডলিং করা যেতে পারে।

উদাহরণ:

async function fetchData() {
  try {
    let response = await fetch('https://api.example.com/data');
    if (!response.ok) {
      throw new Error('Network response was not ok');
    }
    let data = await response.json();
    return data;
  } catch (error) {
    console.error('There was a problem with the fetch operation:', error);
  }
}

fetchData();

এখানে, try...catch ব্লক ব্যবহার করে await এর মধ্যে কোনো এরর হলে তা সহজেই ক্যাচ করা যায়।


Conclusion

Async Functions ES6 এর একটি অত্যন্ত গুরুত্বপূর্ণ ফিচার, যা অ্যাসিঙ্ক্রোনাস কোড লেখাকে আরও সহজ, পরিষ্কার এবং রিডেবল করে তোলে। async এবং await কিওয়ার্ডের মাধ্যমে আপনি অ্যাসিঙ্ক্রোনাস অপারেশনগুলোকে সিঙ্ক্রোনাস কোডের মতো পরিচালনা করতে পারবেন এবং এতে কোডের রিডেবিলিটি, ডিবাগিং সুবিধা, এবং সাধারণ ব্যবস্থাপনা আরও উন্নত হয়।

Content added By
Promotion

Are you sure to start over?

Loading...