Component Attributes এবং Events হ্যান্ডলিং

JSF এর বেসিক UI Components - জেএসএফ (JSF) - Web Development

275

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

Component Attributes


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

কমন কম্পোনেন্ট অ্যাট্রিবিউটস

  1. value: এটি কম্পোনেন্টের মান সংরক্ষণ করে। যেমন একটি টেক্সট ফিল্ডের মান বা বাটনের লেখা।
  2. id: প্রতিটি কম্পোনেন্টের একটি ইউনিক আইডি প্রদান করে, যা ক্লায়েন্ট সাইডে পেজের বিভিন্ন এলিমেন্ট রেফারেন্স করতে ব্যবহৃত হয়।
  3. styleClass: এটি CSS ক্লাস অ্যাট্রিবিউট, যা কম্পোনেন্টের ডিজাইন কাস্টমাইজ করতে ব্যবহৃত হয়।
  4. disabled: এটি একটি বুলিয়ান অ্যাট্রিবিউট, যা কম্পোনেন্টটি নিষ্ক্রিয় বা অক্ষম করে দেয়। যেমন একটি বাটন বা ইনপুট ফিল্ড।
  5. rendered: এটি একটি বুলিয়ান অ্যাট্রিবিউট যা একটি কম্পোনেন্টের দৃশ্যমানতা নিয়ন্ত্রণ করে। যদি এটি false হয়, কম্পোনেন্টটি রেন্ডার হয় না।

উদাহরণ:

<h:inputText value="#{userBean.username}" id="username" styleClass="inputField" />
<h:commandButton value="Submit" action="#{userBean.submit}" disabled="#{userBean.isDisabled}" />

এখানে value অ্যাট্রিবিউট inputText কম্পোনেন্টে ইউজারের ইনপুট মান ধারণ করে, এবং disabled অ্যাট্রিবিউট বাটনটি নিষ্ক্রিয় বা সক্রিয় করবে।

Events Handling in JSF


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

JSF কম্পোনেন্টে ইভেন্ট টাইপ

  1. Action Event: এই ইভেন্টটি সাধারণত কম্পোনেন্টের অ্যাকশন (যেমন একটি বাটন ক্লিক করা) দ্বারা ট্রিগার হয়। উদাহরণস্বরূপ, h:commandButton অথবা h:commandLink
  2. Value Change Event: এটি এমন একটি ইভেন্ট যা তখন ট্রিগার হয় যখন ইউজার একটি ইনপুট কম্পোনেন্টে মান পরিবর্তন করে। এটি সাধারণত h:inputText, h:selectOneMenu ইত্যাদি কম্পোনেন্টে ব্যবহৃত হয়।
  3. Ajax Event: AJAX এর মাধ্যমে সার্ভারের সাথে যোগাযোগ করার জন্য JSF কম্পোনেন্ট ইভেন্ট ব্যবহার করা হয়। এই ইভেন্টটি সাধারণত f:ajax ট্যাগের মাধ্যমে পরিচালিত হয়।

ইভেন্ট হ্যান্ডলিংয়ের উদাহরণ

  1. Action Event Handling (Button Click):

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

    এই উদাহরণে, যখন ইউজার বাটনে ক্লিক করবেন, তখন submit মেথডটি userBean থেকে কল হবে।

    Managed Bean:

    @ManagedBean
    public class UserBean {
        public String submit() {
            // কিছু লজিক
            return "success"; // নেভিগেশন আউটপুট
        }
    }
    
  2. Value Change Event (Input Text):

    <h:inputText value="#{userBean.username}">
        <f:ajax event="valueChange" listener="#{userBean.onValueChange}" />
    </h:inputText>
    

    এখানে, valueChange ইভেন্টটি তখন ট্রিগার হবে যখন ইউজার ইনপুট ফিল্ডে মান পরিবর্তন করবেন এবং onValueChange মেথডটি কল হবে।

    Managed Bean:

    @ManagedBean
    public class UserBean {
        private String username;
        
        public void onValueChange(ValueChangeEvent event) {
            // ইউজারের নতুন ইনপুট হ্যান্ডলিং
            System.out.println("New Value: " + event.getNewValue());
        }
        
        public String getUsername() {
            return username;
        }
    
        public void setUsername(String username) {
            this.username = username;
        }
    }
    
  3. Ajax Event Handling:

    JSF এ f:ajax ট্যাগ ব্যবহার করে AJAX ইভেন্ট পরিচালনা করা হয়। এটি সার্ভারের সাথে যোগাযোগ ছাড়াই পেজের কিছু অংশকে আপডেট করতে সক্ষম।

    <h:inputText value="#{userBean.username}">
        <f:ajax event="blur" render="message" />
    </h:inputText>
    <h:outputText id="message" value="Username is: #{userBean.username}" />
    

    এখানে, যখন ইউজার ইনপুট ফিল্ড থেকে ফোকাস সরিয়ে নিবে (blur ইভেন্ট), তখন message কম্পোনেন্টটি আপডেট হবে।

ইভেন্ট লিসনার


JSF-তে কম্পোনেন্টের ইভেন্ট হ্যান্ডল করার জন্য ইভেন্ট লিসনার ব্যবহার করা হয়। একটি listener অ্যাট্রিবিউট নির্দিষ্ট করে, এটি একটি পদ্ধতি বা মেথড কল করবে যখন নির্দিষ্ট ইভেন্ট ঘটবে। উদাহরণস্বরূপ, f:ajax ট্যাগের মাধ্যমে AJAX ইভেন্ট হ্যান্ডলিং করা হয়, যেখানে একটি listener পদ্ধতি কল করা হয়।

<h:commandButton value="Submit">
    <f:ajax listener="#{userBean.processAction}" />
</h:commandButton>

এখানে, processAction পদ্ধতি userBean থেকে কল হবে যখন বাটনে ক্লিক করা হবে।

সারাংশ


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

Content added By
Promotion

Are you sure to start over?

Loading...