অ্যাজাক্স (Ajax)

Asynchronous এবং Synchronous Ajax এর মধ্যে পার্থক্য

Web Development - অ্যাজাক্স (Ajax) - Ajax এর বেসিক কাজের প্রক্রিয়া (How Ajax Works) | NCTB BOOK

Ajax রিকোয়েস্ট দুটি পদ্ধতিতে কাজ করতে পারে: Asynchronous এবং Synchronous। এই দুটি পদ্ধতির মধ্যে মূল পার্থক্য হলো কিভাবে ব্রাউজার সার্ভারের সাথে যোগাযোগ করে এবং কিভাবে রেসপন্সের জন্য অপেক্ষা করে। নিচে Asynchronous এবং Synchronous Ajax এর মধ্যে পার্থক্য ব্যাখ্যা করা হলো:

Asynchronous Ajax:

১. অ্যাসিনক্রোনাস নেচার:

  • Asynchronous পদ্ধতিতে Ajax রিকোয়েস্ট পাঠানোর পর ব্রাউজার সার্ভারের রেসপন্সের জন্য অপেক্ষা করে না। রিকোয়েস্ট পাঠানোর পর ব্রাউজার অন্যান্য কাজ চালিয়ে যায় এবং যখন রেসপন্স পাওয়া যায় তখন একটি ফাংশন (callback function) এক্সিকিউট হয়।

২. ইউজার ইন্টারফেস ফ্রিজ না হওয়া:

  • এই পদ্ধতিতে রিকোয়েস্ট চলাকালীন সময়ে ওয়েব পেজের ইউজার ইন্টারফেস (UI) প্রতিক্রিয়াশীল থাকে, অর্থাৎ ইউজার অন্যান্য কাজ করতে পারে।

৩. ব্যবহার:

  • সাধারণত, ওয়েব ডেভেলপমেন্টে Ajax রিকোয়েস্ট প্রায় সব সময় অ্যাসিনক্রোনাস (asynchronous) হয়, কারণ এটি ইউজারের অভিজ্ঞতা (user experience) উন্নত করে।

৪. কোড উদাহরণ:

var xhr = new XMLHttpRequest();
xhr.open("GET", "data-url.json", true); // true = Asynchronous
xhr.onreadystatechange = function() {
   if (xhr.readyState === 4 && xhr.status === 200) {
       console.log(xhr.responseText); // রেসপন্স ডেটা প্রসেস করা
   }
};
xhr.send();
  • এখানে, true প্যারামিটারটি নির্দেশ করে যে রিকোয়েস্ট অ্যাসিনক্রোনাসভাবে কাজ করবে। এটি পেজের অন্যান্য কাজ চলমান অবস্থায় রিকোয়েস্ট প্রক্রিয়া চালিয়ে যাবে।

৫. প্রসেসিং ইফিশিয়েন্সি:

  • Asynchronous Ajax ওয়েব অ্যাপ্লিকেশনকে আরও দ্রুত এবং স্মুথ করে তোলে কারণ এটি রেসপন্সের জন্য অপেক্ষা না করে অন্যান্য কাজ চালিয়ে যেতে পারে।

Synchronous Ajax:

১. সিঙ্ক্রোনাস নেচার:

  • Synchronous পদ্ধতিতে Ajax রিকোয়েস্ট পাঠানোর পর ব্রাউজার সার্ভারের রেসপন্স না পাওয়া পর্যন্ত অপেক্ষা করে এবং সেই সময়ে অন্য কোনো কাজ করে না। অর্থাৎ, এটি ইউজার ইন্টারফেস ব্লক করে রাখে যতক্ষণ না রেসপন্স আসে।

২. ইউজার ইন্টারফেস ব্লক করা:

  • রেসপন্স পাওয়া না গেলে পেজের UI ফ্রিজ হয়ে যায় এবং ইউজার অন্য কোনো ইন্টারঅ্যাকশন করতে পারে না, যা ইউজার এক্সপেরিয়েন্সকে খারাপ করে দেয়।

৩. ব্যবহার:

  • বর্তমানে ওয়েব ডেভেলপমেন্টে Synchronous Ajax ব্যবহার খুব কমই করা হয়, কারণ এটি অ্যাসিনক্রোনাস পদ্ধতির তুলনায় কম কার্যকরী এবং ইউজার এক্সপেরিয়েন্সে নেতিবাচক প্রভাব ফেলে।

৪. কোড উদাহরণ:

var xhr = new XMLHttpRequest();
xhr.open("GET", "data-url.json", false); // false = Synchronous
xhr.send();
if (xhr.status === 200) {
   console.log(xhr.responseText); // রেসপন্স ডেটা প্রসেস করা
}
  • এখানে, false প্যারামিটারটি নির্দেশ করে যে রিকোয়েস্টটি সিঙ্ক্রোনাসভাবে কাজ করবে। এটি তখন পর্যন্ত অন্য কোনো কাজ করবে না যতক্ষণ না রেসপন্স পাওয়া যায়।

প্রসেসিং ইফিশিয়েন্সি:

  • Synchronous Ajax ব্যবহার করলে ব্রাউজার অপেক্ষা করে এবং অন্যান্য কাজ থামিয়ে রাখে, ফলে পেজের পারফরম্যান্স কমে যায় এবং ইউজার এক্সপেরিয়েন্স ব্যাহত হয়।

Asynchronous এবং Synchronous Ajax এর মধ্যে পার্থক্য:

বৈশিষ্ট্যAsynchronous AjaxSynchronous Ajax
রেসপন্স টাইমরেসপন্স পাওয়ার জন্য ব্রাউজার অপেক্ষা করে না এবং অন্যান্য কাজ চলমান থাকে।রেসপন্স পাওয়া পর্যন্ত ব্রাউজার অপেক্ষা করে এবং অন্য কোনো কাজ করে না।
UI প্রতিক্রিয়াইউজার ইন্টারফেস প্রতিক্রিয়াশীল থাকে এবং ইউজার অন্যান্য কাজ করতে পারে।UI ব্লক হয়ে যায় এবং ইউজার কিছু করতে পারে না।
ব্যবহারিক সুবিধাদ্রুত এবং স্মুথ, ওয়েব অ্যাপ্লিকেশন তৈরিতে বেশি ব্যবহৃত হয়।UI ফ্রিজ করে, ইউজার এক্সপেরিয়েন্স খারাপ করে।
সেটিংtrue প্যারামিটার দিয়ে সেট করা হয়।false প্যারামিটার দিয়ে সেট করা হয়।

সারসংক্ষেপ:

  • Asynchronous Ajax: এটি প্রায় সব সময় ওয়েব ডেভেলপমেন্টে ব্যবহৃত হয়, কারণ এটি দ্রুত এবং ইউজার-ফ্রেন্ডলি।
  • Synchronous Ajax: এটি বিশেষ ক্ষেত্রে ব্যবহৃত হয়, তবে সাধারণত এড়িয়ে যাওয়া হয় কারণ এটি ইউজারের জন্য ইন্টারফেস ব্লক করে।

Promotion