JSF ফর্মের মাধ্যমে ডেটা সাবমিশন

JSF এর ফর্ম এবং ফর্ম প্রসেসিং - জেএসএফ (JSF) - Web Development

239

JSF (JavaServer Faces) ফ্রেমওয়ার্কে ফর্মের মাধ্যমে ডেটা সাবমিশন একটি সাধারণ এবং গুরুত্বপূর্ণ কার্যকলাপ, যা ব্যবহারকারীর ইনপুট গ্রহণ এবং সার্ভারে প্রক্রিয়া করার জন্য ব্যবহৃত হয়। JSF এর ফর্ম কম্পোনেন্টগুলি ব্যবহারকারীর ডেটা সংগ্রহ করতে এবং সেই ডেটা প্রক্রিয়া করার জন্য Managed Bean-এ প্রেরণ করতে সাহায্য করে। এখানে আমরা দেখবো কিভাবে JSF ফর্ম তৈরি করা যায় এবং ব্যবহারকারীর ইনপুট সার্ভারে সাবমিট করা যায়।

JSF ফর্মের মাধ্যমে ডেটা সাবমিশনের মৌলিক কাঠামো


JSF ফর্ম সাধারণত <h:form> ট্যাগ দিয়ে তৈরি করা হয়। এই ফর্মে একাধিক ইনপুট কম্পোনেন্ট (যেমন টেক্সট ফিল্ড, রেডিও বাটন, চেকবক্স) এবং একটি কম্পোনেন্ট (যেমন সাবমিট বাটন) থাকতে পারে, যা ব্যবহারকারীর ইনপুট গ্রহণ করে এবং ফর্ম সাবমিট করে।

JSF ফর্মের মৌলিক উদাহরণ


এখানে একটি সাধারণ JSF ফর্মের উদাহরণ দেওয়া হলো, যেখানে একটি ব্যবহারকারীর নাম ইনপুট নেওয়া হচ্ছে এবং সেই ইনপুট Managed Bean এ প্রেরণ করা হচ্ছে।

JSF পেজ (XHTML):

<h:form>
    <h:outputLabel for="username" value="Enter your name:" />
    <h:inputText value="#{userBean.username}" id="username" />

    <h:commandButton value="Submit" action="#{userBean.submit}" />
</h:form>

এখানে:

  • <h:form>: এটি JSF ফর্ম ট্যাগ, যা ব্যবহারকারীর ইনপুট গ্রহণের জন্য প্রয়োজন।
  • <h:inputText>: এটি একটি ইনপুট টেক্সট ফিল্ড, যা ব্যবহারকারীর নাম গ্রহণ করবে। value="#{userBean.username}" ব্যবহার করে Managed Bean এর প্রোপার্টি username এর সাথে বাইন্ডিং করা হচ্ছে।
  • <h:commandButton>: এটি একটি কম্পোনেন্ট যা ব্যবহারকারীকে ফর্ম সাবমিট করার জন্য "Submit" বাটন তৈরি করবে। action="#{userBean.submit}" ব্যবহার করে Managed Bean এর submit মেথড কল করা হবে।

Managed Bean (Java):

import javax.faces.bean.ManagedBean;
import javax.faces.bean.RequestScoped;

@ManagedBean
@RequestScoped
public class UserBean {
    private String username;

    public String getUsername() {
        return username;
    }

    public void setUsername(String username) {
        this.username = username;
    }

    public String submit() {
        // বিজনেস লজিক বা ডেটা প্রক্রিয়া
        System.out.println("User's name: " + username);
        return "success";  // ফর্ম সাবমিট হওয়ার পর নেভিগেট করা হবে
    }
}

এখানে:

  • username হল Managed Bean এর প্রোপার্টি, যা ফর্ম থেকে ইনপুট গ্রহণ করবে।
  • submit() মেথডটি ফর্ম সাবমিট হলে কল হবে এবং ইনপুট ডেটা প্রক্রিয়া করবে। এখানে আমরা কেবল System.out.println দিয়ে নামটি প্রদর্শন করছি।
  • return "success"; নেভিগেশন রুলের মাধ্যমে পরবর্তী পৃষ্ঠায় নেভিগেট করবে।

faces-config.xml কনফিগারেশন (অপশনাল):

<navigation-rule>
    <from-view-id>/index.xhtml</from-view-id>
    <navigation-case>
        <from-outcome>success</from-outcome>
        <to-view-id>/success.xhtml</to-view-id>
    </navigation-case>
</navigation-rule>

এখানে:

  • success.xhtml একটি নতুন পৃষ্ঠা হবে যা ফর্ম সাবমিট করার পর রিডাইরেক্ট করবে।

JSF ফর্মের মাধ্যমে ডেটা সাবমিশনের কাজের প্রক্রিয়া


  1. ফর্ম ইনপুট:
    • ব্যবহারকারী h:inputText ফিল্ডে একটি মান (যেমন নাম) প্রদান করে এবং তারপর "Submit" বাটনে ক্লিক করেন।
  2. ডেটা সাবমিট:
    • ক্লিক করার সাথে সাথে JSF ফর্মটি Managed Bean এর submit() মেথডে ইনপুট ডেটা প্রেরণ করে। এই মেথডটি Java ক্লাসে প্রক্রিয়া করা হয়।
  3. ব্যবসায়িক লজিক প্রক্রিয়া:
    • submit() মেথডে আপনি ডেটা ভ্যালিডেশন বা অন্য কোনো ব্যবসায়িক লজিক প্রয়োগ করতে পারেন।
  4. নেভিগেশন:
    • ফর্ম সাবমিট হওয়ার পর, JSF পেজটি পরবর্তী পৃষ্ঠায় নেভিগেট করে (যেমন success.xhtml)।

JSF ফর্মের মাধ্যমে ডেটা সাবমিশনে AJAX ব্যবহার


JSF 2.0 এর সাথে AJAX ব্যবহার করে আপনি ফর্মের ইনপুটের সাথে কোনো পৃষ্ঠার রিফ্রেশ ছাড়াই ডেটা প্রক্রিয়া করতে পারেন। PrimeFaces এর মতো লাইব্রেরি AJAX সমর্থিত কম্পোনেন্ট সরবরাহ করে, তবে আপনি নিজে JSF তেও AJAX ব্যবহার করতে পারেন।

AJAX এর সাথে ফর্ম সাবমিট উদাহরণ:

<h:form>
    <h:outputLabel for="username" value="Enter your name:" />
    <h:inputText value="#{userBean.username}" id="username" />

    <h:commandButton value="Submit" action="#{userBean.submit}">
        <f:ajax execute="@form" render="message" />
    </h:commandButton>

    <h:outputText id="message" value="#{userBean.username}" />
</h:form>

এখানে:

  • <f:ajax> ব্যবহার করে ফর্ম সাবমিট হওয়ার পর পেজ রিফ্রেশ ছাড়াই আউটপুট আপডেট করা হবে।
  • execute="@form" ট্যাগটি ফর্মের সমস্ত ইনপুট কম্পোনেন্ট এক্সিকিউট করে, এবং render="message" আউটপুটটিকে আপডেট করবে।

সারাংশ


JSF ফর্মের মাধ্যমে ডেটা সাবমিশন একটি খুব সাধারণ প্রক্রিয়া যা ব্যবহারকারীর ইনপুট গ্রহণ এবং সেই ডেটা Managed Bean-এ প্রেরণ করে। h:form, h:inputText, এবং h:commandButton ট্যাগগুলির মাধ্যমে ফর্ম তৈরি করা হয়, যেখানে ডেটা ManagedBean এর প্রোপার্টির সাথে বাইন্ড করা হয়। এছাড়া, AJAX ব্যবহার করে ফর্ম সাবমিটের সময় পেজ রিফ্রেশ ছাড়াই ইনপুট ডেটা প্রক্রিয়া করা সম্ভব। JSF এর এই ফিচারগুলো ওয়েব অ্যাপ্লিকেশনের ব্যবহারকারী ইন্টারফেসকে আরও দ্রুত এবং ডাইনামিক করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...