rich:dataTable এবং rich:datatable এর ব্যবহার

RichFaces এর ডাটা টেবিল এবং ডাটা গ্রিড - রিচফেসেস (RichFaces) - Web Development

268

RichFaces একটি শক্তিশালী ফ্রেমওয়ার্ক যা JSF (JavaServer Faces) ভিত্তিক অ্যাপ্লিকেশনগুলির জন্য AJAX এবং Rich UI Components প্রদান করে। এর মধ্যে একটি জনপ্রিয় কম্পোনেন্ট হল rich:dataTable, যা ডাটা টেবিল তৈরি করার জন্য ব্যবহৃত হয়। rich:dataTable ব্যবহার করে আপনি সহজেই ডাটা প্রদর্শন করতে পারেন এবং ডাটা এডিটিং, সর্টিং, পেজিনেশন ইত্যাদি ফিচার যুক্ত করতে পারেন। এখানে rich:dataTable এবং rich:datatable এর ব্যবহার নিয়ে বিস্তারিত আলোচনা করা হয়েছে।

1. rich:dataTable কম্পোনেন্ট

rich:dataTable হল RichFaces এর একটি কম্পোনেন্ট যা JSF এর টেবিলের জন্য ব্যবহৃত হয়। এটি ডাইনামিক এবং ইন্টারেকটিভ টেবিল তৈরি করতে সাহায্য করে, যেখানে আপনি সহজে পেজিনেশন, সিএসএস ক্লাস, ফিল্টারিং, সর্টিং, এবং অন্যান্য উন্নত বৈশিষ্ট্য যুক্ত করতে পারেন।

Basic Usage of rich:dataTable

এখানে একটি সাধারণ rich:dataTable ব্যবহার উদাহরণ দেওয়া হলো, যেখানে কিছু ডেটা প্রদর্শন করা হচ্ছে:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:rich="http://richfaces.org/rich">

<h:head>
    <title>rich:dataTable Example</title>
</h:head>

<h:body>

    <rich:dataTable value="#{bean.items}" var="item" cellpadding="5" cellspacing="0" styleClass="table" border="1">
        <rich:column>
            <f:facet name="header">
                <h:outputText value="ID" />
            </f:facet>
            <h:outputText value="#{item.id}" />
        </rich:column>

        <rich:column>
            <f:facet name="header">
                <h:outputText value="Name" />
            </f:facet>
            <h:outputText value="#{item.name}" />
        </rich:column>

        <rich:column>
            <f:facet name="header">
                <h:outputText value="Email" />
            </f:facet>
            <h:outputText value="#{item.email}" />
        </rich:column>
    </rich:dataTable>

</h:body>
</html>

Explanation:

  1. value="#{bean.items}": এটি একটি ব্যাকেন্ড মেথড বা প্রপার্টি থেকে ডেটা নিয়ে আসে (যেমন, bean.items যা একটি লিস্ট বা ম্যাপ হতে পারে)।
  2. var="item": টেবিলের প্রতিটি রো-এর জন্য একটি ভ্যারিয়েবল item হিসেবে ব্যবহার হবে, যাতে আমরা টেবিলের প্রতিটি সেল থেকে ডেটা অ্যাক্সেস করতে পারি।
  3. rich:column: প্রতিটি কলামের জন্য rich:column ব্যবহার করা হয়। এর মধ্যে f:facet ব্যবহার করে কলামের হেডার টেক্সট এবং সেলের ডেটা নির্ধারণ করা হয়।

RichFaces DataTable with Pagination Example

Pagination বা পেজিনেশন একটি গুরুত্বপূর্ণ ফিচার যা ব্যবহারকারীদের বড় ডেটাসেট সহজে ব্রাউজ করার সুযোগ দেয়। নিচে rich:dataTable এ পেজিনেশন যুক্ত করার উদাহরণ দেওয়া হলো:

<rich:dataTable value="#{bean.items}" var="item" cellpadding="5" cellspacing="0" styleClass="table" border="1" rows="5">
    <rich:column>
        <f:facet name="header">
            <h:outputText value="ID" />
        </f:facet>
        <h:outputText value="#{item.id}" />
    </rich:column>

    <rich:column>
        <f:facet name="header">
            <h:outputText value="Name" />
        </f:facet>
        <h:outputText value="#{item.name}" />
    </rich:column>

    <rich:column>
        <f:facet name="header">
            <h:outputText value="Email" />
        </f:facet>
        <h:outputText value="#{item.email}" />
    </rich:column>

    <!-- Pagination Controls -->
    <rich:datascroller for="table" />
</rich:dataTable>

Explanation:

  • rows="5": এই অ্যাট্রিবিউটটি প্রতি পেজে ৫টি রো প্রদর্শন করবে।
  • rich:datascroller: এটি পেজিনেশন কন্ট্রোল তৈরি করে, যাতে ব্যবহারকারী ডেটা স্ক্রল বা পেজ নেভিগেট করতে পারে।

2. rich:datatable এর ব্যবহার

rich:datatable হল একটি শক্তিশালী JSF টেবিল কম্পোনেন্ট যা RichFaces ফ্রেমওয়ার্কের অংশ। এটি অনেক উন্নত ফিচার যেমন সর্টিং, ফিল্টারিং, পেজিনেশন, এবং AJAX সাপোর্ট সহ আসে।

Basic Usage of rich:datatable

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml"
      xmlns:f="http://java.sun.com/jsf/core"
      xmlns:h="http://java.sun.com/jsf/html"
      xmlns:rich="http://richfaces.org/rich">

<h:head>
    <title>rich:datatable Example</title>
</h:head>

<h:body>

    <rich:datatable value="#{bean.items}" var="item" cellpadding="5" cellspacing="0" styleClass="table" border="1">
        <rich:column>
            <f:facet name="header">
                <h:outputText value="ID" />
            </f:facet>
            <h:outputText value="#{item.id}" />
        </rich:column>

        <rich:column>
            <f:facet name="header">
                <h:outputText value="Name" />
            </f:facet>
            <h:outputText value="#{item.name}" />
        </rich:column>

        <rich:column>
            <f:facet name="header">
                <h:outputText value="Email" />
            </f:facet>
            <h:outputText value="#{item.email}" />
        </rich:column>

    </rich:datatable>

</h:body>
</html>

Explanation:

  • rich:datatable: এটি একটি উন্নত টেবিল কম্পোনেন্ট, যা ডাটা তালিকা প্রদর্শন করতে ব্যবহৃত হয়। এটিতে পেজিনেশন, ফিল্টারিং এবং সটিং সাপোর্ট রয়েছে।
  • AJAX সাপোর্টের মাধ্যমে টেবিলের ডেটা দ্রুত রিফ্রেশ করা যায়, যা পেজ রিফ্রেশ না করেই ডেটা আপডেট করতে সাহায্য করে।

rich:datatable with Sorting Example

<rich:datatable value="#{bean.items}" var="item" cellpadding="5" cellspacing="0" styleClass="table" border="1" sortMode="multiple">
    <rich:column sortBy="#{item.name}">
        <f:facet name="header">
            <h:outputText value="Name" />
        </f:facet>
        <h:outputText value="#{item.name}" />
    </rich:column>

    <rich:column sortBy="#{item.email}">
        <f:facet name="header">
            <h:outputText value="Email" />
        </f:facet>
        <h:outputText value="#{item.email}" />
    </rich:column>
</rich:datatable>

Explanation:

  • sortBy: এই অ্যাট্রিবিউটটি ডেটা কলামটি সোর্ট করার জন্য ব্যবহৃত হয়।
  • sortMode="multiple": একাধিক কলাম সোর্ট করার অনুমতি দেয়।

3. Advanced Features of rich:dataTable

rich:dataTable বিভিন্ন উন্নত ফিচার যেমন pagination, sorting, filtering, ajax support, এবং dynamic updates সমর্থন করে।

  • Filtering: টেবিলের উপর ফিল্টারিং যুক্ত করা সম্ভব।
  • Ajax support: টেবিলের কন্টেন্ট একাধিক কলামে ডাইনামিকভাবে লোড করা যায় AJAX এর মাধ্যমে।
  • Paginable tables: বড় ডেটাসেট দেখার জন্য পেজিনেশন সুবিধা প্রদান করে।
  • Resizable columns: ব্যবহারকারীদের জন্য কলাম রিসাইজ করা।

RichFaces এর rich:dataTable এবং rich:datatable কম্পোনেন্টগুলো JSF অ্যাপ্লিকেশনগুলির মধ্যে উন্নত এবং ডাইনামিক টেবিল তৈরি করতে সাহায্য করে। আপনি এগুলির মাধ্যমে AJAX, sorting, pagination, এবং filtering যুক্ত করে ইউজার ইন্টারফেসকে আরও উন্নত এবং ইন্টারঅ্যাকটিভ করতে পারবেন। RichFaces টেবিল কম্পোনেন্টগুলোর মাধ্যমে আপনি সহজেই এবং দ্রুত ইন্টারেকটিভ এবং ফিচার-পূর্ণ ওয়েব অ্যাপ্লিকেশন তৈরি করতে পারবেন।

Content added By
Promotion

Are you sure to start over?

Loading...