পেজের মধ্যে Component যোগ করা

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

224

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

এখানে, JSF পেজে বিভিন্ন কম্পোনেন্ট যোগ করার পদ্ধতি আলোচনা করা হলো।

JSF কম্পোনেন্টের ধরন


JSF-এ বিভিন্ন ধরনের UI কম্পোনেন্ট রয়েছে, যেগুলোর মাধ্যমে পেজে ইনপুট, আউটপুট, লেআউট ইত্যাদি প্রদর্শন করা যায়। কিছু প্রধান কম্পোনেন্টের মধ্যে রয়েছে:

  • Input Components (ইনপুট কম্পোনেন্ট): ইউজারের কাছ থেকে ডেটা ইনপুট গ্রহণ করে। যেমন h:inputText, h:inputSecret, h:selectOneMenu ইত্যাদি।
  • Output Components (আউটপুট কম্পোনেন্ট): ডেটা প্রদর্শন করে। যেমন h:outputText, h:outputLabel ইত্যাদি।
  • Action Components (অ্যাকশন কম্পোনেন্ট): ইউজারের কোনো অ্যাকশন গ্রহণ করে। যেমন h:commandButton, h:commandLink ইত্যাদি।
  • Layout Components (লেআউট কম্পোনেন্ট): পেজের লেআউট তৈরি করে। যেমন h:panelGrid, h:form, h:panelGroup ইত্যাদি।

কম্পোনেন্ট যোগ করার উদাহরণ


১. ইনপুট কম্পোনেন্ট (Input Component)

ইনপুট কম্পোনেন্টের মাধ্যমে ইউজার তথ্য প্রদান করতে পারে। যেমন, একটি টেক্সট ইনপুট:

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

এখানে:

  • h:inputText: একটি টেক্সট ইনপুট ফিল্ড তৈরি করে, যার মাধ্যমে ইউজার নাম ইনপুট দিতে পারবে।
  • value: এই অ্যাট্রিবিউটটি userBean.username এর সাথে বাইন্ড করা, যা Managed Bean এর একটি প্রপার্টি।
  • h:commandButton: একটি বাটন তৈরি করে, যা ইউজারের ইনপুট সাবমিট করার জন্য ব্যবহার করা হয়।

২. আউটপুট কম্পোনেন্ট (Output Component)

আউটপুট কম্পোনেন্ট ডেটা প্রদর্শনের জন্য ব্যবহার করা হয়। যেমন, একটি টেক্সট আউটপুট:

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

এখানে:

  • h:outputText: এটি userBean.message প্রপার্টির মান দেখায়। মানটি Managed Bean থেকে আনা হবে এবং পেজে প্রদর্শিত হবে।

৩. ড্রপডাউন লিস্ট (Select One Menu)

একটি ড্রপডাউন মেনু তৈরি করতে JSF ব্যবহার করা হয় h:selectOneMenu কম্পোনেন্ট:

<h:form>
    <h:selectOneMenu value="#{userBean.selectedItem}">
        <f:selectItem itemLabel="Item 1" itemValue="1" />
        <f:selectItem itemLabel="Item 2" itemValue="2" />
        <f:selectItem itemLabel="Item 3" itemValue="3" />
    </h:selectOneMenu>
</h:form>

এখানে:

  • h:selectOneMenu: একটি ড্রপডাউন মেনু তৈরি করে, যেখানে f:selectItem এর মাধ্যমে বিকল্পসমূহ দেখানো হয়।
  • value: এটি userBean.selectedItem এর সাথে বাইন্ড করা থাকে, যাতে ইউজার নির্বাচিত আইটেমটি ম্যানেজড বিইনের প্রপার্টি হিসেবে পাওয়া যায়।

৪. ফর্ম কম্পোনেন্ট (Form Component)

JSF তে ফর্ম ব্যবহার করা খুবই সাধারণ। নিচে একটি সিম্পল ফর্ম কম্পোনেন্ট:

<h:form>
    <h:inputText value="#{userBean.name}" label="Name" />
    <h:inputSecret value="#{userBean.password}" label="Password" />
    <h:commandButton value="Login" action="#{userBean.login}" />
</h:form>

এখানে:

  • h:form: ফর্ম কম্পোনেন্ট, যা ইনপুট কম্পোনেন্ট এবং সাবমিট বাটন ধারণ করে।
  • h:inputText: ইউজারের নাম ইনপুট নেওয়ার জন্য।
  • h:inputSecret: পাসওয়ার্ড ইনপুট নেওয়ার জন্য।
  • h:commandButton: ফর্ম সাবমিট করার জন্য।

৫. প্যানেল গ্রিড (Panel Grid)

পেজের লেআউট তৈরি করতে h:panelGrid কম্পোনেন্ট ব্যবহার করা হয়:

<h:form>
    <h:panelGrid columns="2">
        <h:outputLabel for="username" value="Username:" />
        <h:inputText id="username" value="#{userBean.username}" />

        <h:outputLabel for="password" value="Password:" />
        <h:inputSecret id="password" value="#{userBean.password}" />
    </h:panelGrid>
</h:form>

এখানে:

  • h:panelGrid: এটি একটি টেবিলের মতো লেআউট তৈরি করে, যেখানে columns="2" দ্বারা দুটি কলাম নির্ধারণ করা হয়েছে।
  • h:outputLabel: প্রতিটি ইনপুট ফিল্ডের জন্য লেবেল তৈরি করে।

কম্পোনেন্টের লাইফসাইকেল


JSF কম্পোনেন্টের একটি নির্দিষ্ট লাইফসাইকেল থাকে। এই লাইফসাইকেলটি বিভিন্ন স্টেপে বিভক্ত, যেমন:

  1. Build Phase: কম্পোনেন্ট তৈরি করা হয় এবং HTML উপাদান হিসেবে রেন্ডার করা হয়।
  2. Render Phase: HTML রেন্ডারিং সম্পন্ন হয় এবং ব্যবহারকারীর ব্রাউজারে প্রদর্শিত হয়।
  3. Event Handling: ইউজারের ইনপুট এবং অ্যাকশন পরিচালনা করা হয়।

JSF কম্পোনেন্টের সাথে Managed Beans এর ইন্টিগ্রেশন


JSF কম্পোনেন্টগুলো Managed Beans এর সাথে যুক্ত থাকে, যাতে ডেটা বিনিময় করা যায় এবং ব্যবসায়িক লজিক পরিচালনা করা যায়। value="#{bean.property}" এই সিনট্যাক্সের মাধ্যমে UI কম্পোনেন্টের ইনপুট বা আউটপুটকে Managed Bean এর প্রপার্টির সাথে বাইন্ড করা হয়।


সারাংশ


JSF এর মাধ্যমে পেজে বিভিন্ন কম্পোনেন্ট যোগ করা যায়, যা ইউজারের ইনপুট গ্রহণ, আউটপুট প্রদর্শন, এবং অ্যাকশন প্রক্রিয়া করার জন্য ব্যবহার করা হয়। JSF কম্পোনেন্টগুলোর মাধ্যমে খুব সহজেই ডাইনামিক ওয়েব পেজ তৈরি করা সম্ভব, যা ব্যবহারকারীর ইন্টারঅ্যাকশন এবং ডেটা হ্যান্ডলিংকে সোজা ও কার্যকর করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...