AJAX এবং JSON এর মাধ্যমে ডেটা হ্যান্ডলিং

KnockoutJS এবং AJAX Integration - নকআউটজেএস (KnockoutJS) - Web Development

355

KnockoutJS একটি শক্তিশালী JavaScript লাইব্রেরি যা MVVM (Model-View-ViewModel) আর্কিটেকচার প্যাটার্ন অনুসরণ করে এবং UI এবং ডেটার মধ্যে সিঙ্ক্রোনাইজেশন পরিচালনা করে। AJAX এবং JSON এর মাধ্যমে ডেটা হ্যান্ডলিং করার জন্য, KnockoutJS observable এবং computed observables এর সাথে একত্রে AJAX রিকোয়েস্ট পাঠিয়ে এবং JSON ডেটা প্রক্রিয়া করে ডাইনামিক ওয়েব অ্যাপ্লিকেশন তৈরি করতে সহায়তা করে।

AJAX এবং JSON এর মাধ্যমে KnockoutJS এ ডেটা হ্যান্ডলিং

AJAX (Asynchronous JavaScript and XML) হলো একটি প্রযুক্তি যা ব্রাউজার এবং সার্ভারের মধ্যে অ্যাসিঙ্ক্রোনাস যোগাযোগের মাধ্যমে ডেটা আদান প্রদান করতে ব্যবহৃত হয়। JSON (JavaScript Object Notation) হল একটি হালকা ডেটা বিনিময় ফরম্যাট যা সার্ভার এবং ক্লায়েন্টের মধ্যে ডেটা প্রেরণ করতে ব্যবহৃত হয়।

KnockoutJS তে AJAX এবং JSON ব্যবহারের মাধ্যমে আপনি ডেটা সার্ভার থেকে নিতে পারেন এবং observable ডেটার মাধ্যমে তা UI তে রেন্ডার করতে পারেন। এছাড়াও, আপনি two-way data binding এর মাধ্যমে ইউজার ইনপুট থেকে প্রাপ্ত ডেটা সার্ভারে পাঠাতে পারেন।

1. KnockoutJS তে AJAX এবং JSON এর মাধ্যমে ডেটা হ্যান্ডলিং

Step 1: JSON ডেটা সার্ভার থেকে পেতে AJAX রিকোয়েস্ট ব্যবহার করা

এখানে একটি উদাহরণ দেওয়া হল যেখানে আমরা একটি JSON ডেটা সার্ভার থেকে AJAX এর মাধ্যমে গ্রহণ করব এবং KnockoutJS এর observable ডেটার মাধ্যমে তা UI তে রেন্ডার করব।

HTML Example (AJAX with KnockoutJS):
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>KnockoutJS with AJAX and JSON</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.5.1/knockout-min.js"></script>
</head>
<body>

    <h2>Users List</h2>
    <ul data-bind="foreach: users">
        <li>
            <strong data-bind="text: name"></strong> - <span data-bind="text: email"></span>
        </li>
    </ul>

    <script>
        function AppViewModel() {
            var self = this;
            
            // Observable array to hold users data
            self.users = ko.observableArray([]);

            // Function to load users data using AJAX
            self.loadUsers = function() {
                // AJAX call to get data
                var xhr = new XMLHttpRequest();
                xhr.open('GET', 'https://jsonplaceholder.typicode.com/users', true);
                xhr.onreadystatechange = function() {
                    if (xhr.readyState == 4 && xhr.status == 200) {
                        var data = JSON.parse(xhr.responseText);  // Parse the JSON response
                        // Update the observable array with fetched data
                        self.users(data);
                    }
                };
                xhr.send();
            };

            // Load users data on initialization
            self.loadUsers();
        }

        // Activate KnockoutJS bindings
        ko.applyBindings(new AppViewModel());
    </script>

</body>
</html>

Explanation:

  • এখানে, self.users = ko.observableArray([]) একটি observable array তৈরি করেছে যেখানে আমরা AJAX রিকোয়েস্টের মাধ্যমে users ডেটা জমা করব।
  • XMLHttpRequest ব্যবহার করে AJAX রিকোয়েস্ট পাঠানো হচ্ছে, এবং JSON রেসপন্স পেয়েই আমরা তা observableArray তে সেট করে দিচ্ছি। এরপর, data-bind="foreach: users" এর মাধ্যমে আমরা ডেটা UI তে রেন্ডার করছি।

AJAX এর মাধ্যমে POST রিকোয়েস্টের মাধ্যমে ডেটা পাঠানো:

এছাড়াও, KnockoutJS এর মাধ্যমে AJAX POST রিকোয়েস্ট ব্যবহার করে আপনি ডেটা সার্ভারে পাঠাতে পারেন।

self.submitData = function(newUserData) {
    var xhr = new XMLHttpRequest();
    xhr.open('POST', 'https://jsonplaceholder.typicode.com/users', true);
    xhr.setRequestHeader('Content-Type', 'application/json');

    var data = JSON.stringify(newUserData);  // Convert JavaScript object to JSON string
    xhr.onreadystatechange = function() {
        if (xhr.readyState == 4 && xhr.status == 201) {
            var response = JSON.parse(xhr.responseText);
            console.log("User submitted:", response);
        }
    };
    xhr.send(data);  // Send the data as JSON
};

এখানে, submitData() ফাংশন একটি POST রিকোয়েস্ট পাঠাচ্ছে সার্ভারে ডেটা পাঠানোর জন্য।


2. Handling User Input with KnockoutJS and AJAX

এখন আমরা ইউজারের ইনপুট নেওয়া এবং তা সার্ভারে পাঠানো দেখব, যেখানে KnockoutJS এর observable এবং AJAX রিকোয়েস্ট ব্যবহার করা হবে।

Example: Submit Form Data Using KnockoutJS and AJAX

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>KnockoutJS Form Submission with AJAX</title>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.5.1/knockout-min.js"></script>
</head>
<body>

    <h2>Submit a New User</h2>

    <form data-bind="submit: submitUser">
        <label for="name">Name:</label>
        <input type="text" id="name" data-bind="value: userName" required>
        
        <label for="email">Email:</label>
        <input type="email" id="email" data-bind="value: userEmail" required>
        
        <button type="submit">Submit</button>
    </form>

    <script>
        function AppViewModel() {
            var self = this;
            
            // Observables for user input
            self.userName = ko.observable('');
            self.userEmail = ko.observable('');

            // Submit user data via AJAX
            self.submitUser = function() {
                var userData = {
                    name: self.userName(),
                    email: self.userEmail()
                };

                var xhr = new XMLHttpRequest();
                xhr.open('POST', 'https://jsonplaceholder.typicode.com/users', true);
                xhr.setRequestHeader('Content-Type', 'application/json');

                var data = JSON.stringify(userData);  // Convert JavaScript object to JSON
                xhr.onreadystatechange = function() {
                    if (xhr.readyState == 4 && xhr.status == 201) {
                        var response = JSON.parse(xhr.responseText);
                        console.log("User submitted:", response);
                        alert("User submitted successfully!");
                    }
                };
                xhr.send(data);  // Send the data as JSON
            };
        }

        // Activating KnockoutJS bindings
        ko.applyBindings(new AppViewModel());
    </script>

</body>
</html>

Explanation:

  • এখানে, আমরা দুটি observable ডেটা userName এবং userEmail তৈরি করেছি। ইউজারের ইনপুট ডেটা observable এ সেভ হবে।
  • submitUser ফাংশনটি ইউজারের ইনপুট ডেটা নিয়ে একটি AJAX POST রিকোয়েস্ট পাঠাচ্ছে সার্ভারে। সার্ভার থেকে রেসপন্স পাওয়ার পর, তা কনসোলে প্রদর্শিত হচ্ছে এবং ইউজারকে একটি সফল সাবমিশন বার্তা দেওয়া হচ্ছে।

3. Error Handling in AJAX Requests

KnockoutJS তে AJAX রিকোয়েস্টের মাধ্যমে ডেটা গ্রহণ বা পাঠানোর সময় error handling করা খুবই গুরুত্বপূর্ণ। এখানে AJAX error handling এর মাধ্যমে রিকোয়েস্টে কোনো সমস্যা হলে তা পরিচালনা করা হবে।

xhr.onreadystatechange = function() {
    if (xhr.readyState == 4) {
        if (xhr.status == 200 || xhr.status == 201) {
            var response = JSON.parse(xhr.responseText);
            console.log("Success:", response);
        } else {
            console.log("Error:", xhr.status, xhr.statusText);
        }
    }
};

এখানে, xhr.status এর মাধ্যমে HTTP স্ট্যাটাস কোড চেক করে, সফল রিকোয়েস্ট এবং ব্যর্থ রিকোয়েস্টের জন্য আলাদা আলাদা কনসোল লোগ দেওয়া হয়েছে।


KnockoutJS এর সাথে AJAX এবং JSON ব্যবহারের মাধ্যমে ডেটা হ্যান্ডলিং খুবই সহজ এবং কার্যকরী। AJAX রিকোয়েস্ট এবং observable ডেটার মাধ্যমে আপনি two-way data binding সেটআপ করতে পারেন এবং ইউজারের ইনপুট এবং সার্ভারের মধ্যে স্বয়ংক্রিয় ডেটা সিঙ্ক্রোনাইজেশন করতে পারেন। এর মাধ্যমে আপনি

dynamic এবং real-time অ্যাপ্লিকেশন তৈরি করতে পারবেন, যা ব্যবহারকারীর এক্সপেরিয়েন্স উন্নত করবে।

Content added By
Promotion

Are you sure to start over?

Loading...