Ajax এর মাধ্যমে Custom Error Messages

Web Development - অ্যাজাক্স (Ajax) - Ajax এর মাধ্যমে Error Handling (Error Handling in Ajax) |
9
9

Ajax এর মাধ্যমে Custom Error Messages প্রদর্শন করা একটি কার্যকরী পদ্ধতি, যা ব্যবহারকারীদের সঠিক এবং ব্যবহারযোগ্য ত্রুটি বার্তা দেখাতে সাহায্য করে। এর মাধ্যমে ব্যবহারকারী বুঝতে পারে কেন রিকোয়েস্ট ব্যর্থ হয়েছে এবং এর জন্য কী পদক্ষেপ নেওয়া যেতে পারে। নিচে Ajax রিকোয়েস্টে কাস্টম এরর মেসেজ প্রদর্শনের একটি উদাহরণ এবং এর ধাপগুলো আলোচনা করা হলো।

উদাহরণ: Ajax এর মাধ্যমে Custom Error Messages প্রদর্শন করা

HTML (index.html):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Ajax Custom Error Messages Example</title>
</head>
<body>
    <h1>Ajax Request with Custom Error Messages</h1>
    <button onclick="fetchData()">Fetch Data</button>
    <div id="data-container">
        <!-- ডেটা বা ত্রুটি মেসেজ এখানে দেখানো হবে -->
    </div>

    <script src="app.js"></script>
</body>
</html>

বিস্তারিত ব্যাখ্যা:

  • HTML ফাইলে একটি শিরোনাম (<h1>), একটি বোতাম (<button>), এবং একটি <div> এলিমেন্ট রয়েছে।
  • "Fetch Data" বোতামে ক্লিক করলে fetchData() ফাংশন কল হবে, যা Ajax রিকোয়েস্ট করে ডেটা বা ত্রুটি বার্তা দেখাবে।
  • data-container নামে একটি <div> এলিমেন্ট রয়েছে, যেখানে ডেটা বা ত্রুটি বার্তা দেখানো হবে।

JavaScript (app.js):

function fetchData() {
    // XMLHttpRequest অবজেক্ট তৈরি করা
    var xhr = new XMLHttpRequest();
    
    // GET রিকোয়েস্ট ওপেন করা
    xhr.open("GET", "https://jsonplaceholder.typicode.com/posts/101", true); // একটি ভুল URL (404 এরর তৈরি করতে)
    
    // রেসপন্স হ্যান্ডলিং সেট করা
    xhr.onreadystatechange = function() {
        if (xhr.readyState === 4) { // রিকোয়েস্ট সম্পূর্ণ হয়েছে কিনা তা চেক করা
            if (xhr.status === 200) { // রিকোয়েস্ট সফল হলে
                var data = JSON.parse(xhr.responseText); // JSON ডেটা প্রসেস করা
                document.getElementById("data-container").innerHTML = `
                    <h2>${data.title}</h2>
                    <p>${data.body}</p>
                `;
            } else {
                // Custom Error Message
                displayCustomErrorMessage(xhr.status);
            }
        }
    };
    
    // ত্রুটি হ্যান্ডলিংয়ের জন্য onerror ইভেন্ট হ্যান্ডলার সেট করা
    xhr.onerror = function() {
        document.getElementById("data-container").innerHTML = "Network error occurred! Please check your internet connection.";
    };
    
    // রিকোয়েস্ট পাঠানো
    xhr.send();
}

// কাস্টম এরর মেসেজ প্রদর্শনের ফাংশন
function displayCustomErrorMessage(status) {
    var message;
    switch (status) {
        case 404:
            message = "Error 404: The requested resource could not be found.";
            break;
        case 500:
            message = "Error 500: Internal Server Error. Please try again later.";
            break;
        case 403:
            message = "Error 403: Access forbidden. You do not have permission to access this resource.";
            break;
        default:
            message = "An unexpected error occurred. Please try again.";
    }
    document.getElementById("data-container").innerHTML = message;
}

ব্যাখ্যা:

XMLHttpRequest অবজেক্ট তৈরি করা:

  • fetchData() ফাংশনে একটি XMLHttpRequest অবজেক্ট তৈরি করা হয়েছে, যা Ajax রিকোয়েস্ট পরিচালনা করবে।

রিকোয়েস্ট ওপেন করা:

  • xhr.open("GET", "https://jsonplaceholder.typicode.com/posts/101", true); মেথড ব্যবহার করে একটি GET রিকোয়েস্ট সেটআপ করা হয়েছে। এখানে ইচ্ছাকৃতভাবে একটি ভুল URL ব্যবহার করা হয়েছে, যাতে 404 এরর তৈরি হয়।

onreadystatechange ইভেন্টে কাস্টম এরর মেসেজ হ্যান্ডলিং:

  • xhr.onreadystatechange ইভেন্টে চেক করা হয়েছে যে রিকোয়েস্ট সম্পূর্ণ হয়েছে কিনা (xhr.readyState === 4) এবং তারপর xhr.status চেক করা হয়েছে।
  • যদি xhr.status === 200 না হয়, তাহলে displayCustomErrorMessage() ফাংশন কল করা হয়েছে, যা স্ট্যাটাস কোডের উপর ভিত্তি করে কাস্টম এরর মেসেজ দেখায়।

onerror ইভেন্ট হ্যান্ডলার:

  • যদি নেটওয়ার্কের কারণে কোনো সমস্যা হয়, যেমন ইন্টারনেট কানেকশন না থাকা, তাহলে xhr.onerror ইভেন্ট হ্যান্ডলার সেই ত্রুটি হ্যান্ডেল করে এবং একটি কাস্টম মেসেজ দেখায়।

কাস্টম এরর মেসেজ প্রদর্শনের ফাংশন:

  • displayCustomErrorMessage() ফাংশন স্ট্যাটাস কোডের উপর ভিত্তি করে বিভিন্ন ত্রুটি মেসেজ প্রদর্শন করে:
    • 404: "The requested resource could not be found."
    • 500: "Internal Server Error. Please try again later."
    • 403: "Access forbidden. You do not have permission to access this resource."
    • Default: "An unexpected error occurred. Please try again."

Error Management এর ধাপগুলো:

  1. HTTP Status Code চেক করা: xhr.status ব্যবহার করে সার্ভার থেকে প্রাপ্ত স্ট্যাটাস চেক করা এবং কাস্টম মেসেজ প্রদর্শন করা।
  2. onreadystatechange ইভেন্টে ত্রুটি দেখানো: যদি status !== 200 হয়, তাহলে HTML ডিভে একটি কাস্টম ত্রুটি মেসেজ দেখানো।
  3. onerror ইভেন্ট হ্যান্ডলিং: নেটওয়ার্ক সমস্যা হ্যান্ডেল করা এবং উপযুক্ত মেসেজ দেখানো।

সারসংক্ষেপ:

  • Ajax রিকোয়েস্টের সময় কাস্টম এরর মেসেজ প্রদর্শনের জন্য onreadystatechange এবং onerror ইভেন্ট হ্যান্ডলার ব্যবহার করা হয়।
  • HTTP Status Code চেক করে কাস্টম মেসেজ প্রদর্শন করা হয়, যা ব্যবহারকারীদের সঠিক তথ্য প্রদান করে এবং তাদের পরবর্তী পদক্ষেপ নিতে সহায়তা করে।
  • কাস্টম এরর মেসেজ ওয়েব অ্যাপ্লিকেশনকে আরও ইউজার-ফ্রেন্ডলি এবং রেসপন্সিভ করে তোলে।

এই উদাহরণটি অনুসরণ করে আপনি Ajax রিকোয়েস্টের সময় কাস্টম এরর মেসেজ সঠিকভাবে প্রদর্শন করতে পারবেন, যা আপনার ওয়েব অ্যাপ্লিকেশনকে আরও ব্যবহারযোগ্য করে তুলবে।

Promotion