जेएसएफ - समग्र घटक

JSF डेवलपर्स को अपने स्वयं के कस्टम घटकों को परिभाषित करने के लिए एक शक्तिशाली क्षमता प्रदान करता है, जिसका उपयोग कस्टम सामग्री को प्रस्तुत करने के लिए किया जा सकता है।

कस्टम घटक परिभाषित करें

जेएसएफ में एक कस्टम घटक को परिभाषित करना दो चरणों वाली प्रक्रिया है।

कदम विवरण
1 क

एक संसाधन फ़ोल्डर बनाएँ।

एक संयुक्त नाम स्थान के साथ संसाधन फ़ोल्डर में एक एक्सएचटीएमएल फ़ाइल बनाएँ।

1b

समग्र टैग का उपयोग करें समग्र : इंटरफ़ेस, समग्र: विशेषता और समग्र: कार्यान्वयन, समग्र घटक की सामग्री को परिभाषित करने के लिए। समग्र में cattatt का उपयोग करें : समग्र का उपयोग करके परिभाषित चर प्राप्त करने के लिए कार्यान्वयन : समग्र में विशेषता : इंटरफ़ेस

चरण 1 ए: कस्टम घटक बनाएँ: loginComponent.xhtml

संसाधन फ़ोल्डर में एक फ़ोल्डर ट्यूटोरियलस्पॉट बनाएँ और उसमें एक फ़ाइल loginComponent.xhtml बनाएं।

Html शीर्ष लेख में संयुक्त नाम स्थान का उपयोग करें।

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

चरण 1 बी: कम्पोजिट टैग का उपयोग करें: loginComponent.xhtml

निम्न तालिका में समग्र टैग के उपयोग का वर्णन है।

S.No टैग और विवरण
1

composite:interface

समग्र रूप से उपयोग किए जाने वाले विन्यास योग्य मूल्यों की घोषणा करता है: कार्यान्वयन।

2

composite:attribute

इस टैग का उपयोग करके कॉन्फ़िगरेशन मान घोषित किए जाते हैं।

3

composite:implementation

जेएसएफ घटक घोषित करता है। समग्र में परिभाषित विन्यास मूल्यों का उपयोग कर सकते हैं: # {cc.attrs.attribute-name} अभिव्यक्ति का उपयोग करके इंटरफ़ेस।

<composite:interface>
   <composite:attribute name = "usernameLabel" />
   <composite:attribute name = "usernameValue" />
</composite:interface>

<composite:implementation>
<h:form>
   #{cc.attrs.usernameLabel} : 
   <h:inputText id = "username" value = "#{cc.attrs.usernameValue}" />
</h:form>

कस्टम घटक का उपयोग करें

JSF में एक कस्टम घटक का उपयोग करना एक सरल प्रक्रिया है।

कदम विवरण
2a एक एक्सएचटीएमएल फ़ाइल बनाएँ और कस्टम घटक के नाम स्थान का उपयोग करें। Namespace http://java.sun.com/jsf/ <folder-name> होगा जहाँ फ़ोल्डर-नाम कस्टम घटक वाले संसाधन निर्देशिका में फ़ोल्डर है
2 बी सामान्य जेएसएफ टैग के रूप में कस्टम घटक का उपयोग करें

चरण 2a: कस्टम नामस्थान का उपयोग करें: home.xhtml

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:ui = "http://java.sun.com/jsf/facelets">
   xmlns:tp = "http://java.sun.com/jsf/composite/tutorialspoint">

चरण 2 बी: कस्टम टैग का उपयोग करें: home.xhtml और पास मान

<h:form>
   <tp:loginComponent 
      usernameLabel = "Enter User Name: " 
      usernameValue = "#{userData.name}" />
</h:form>

उदाहरण अनुप्रयोग

हमें JSF में कस्टम घटक का परीक्षण करने के लिए एक परीक्षण JSF एप्लिकेशन बनाएँ।

कदम विवरण
1 एक नाम के साथ एक प्रोजेक्ट बना HelloWorld एक पैकेज के तहत com.tutorialspoint.test में बताई गई विधि पहले आवेदन - JSF अध्याय।
2 Src → मुख्य फ़ोल्डर के तहत संसाधन फ़ोल्डर बनाएँ ।
3 Src → मुख्य → संसाधन फ़ोल्डर के तहत ट्यूटोरियलस्पॉट फ़ोल्डर बनाएँ ।
4 Src → मुख्य → संसाधनों → tutorialspoint फ़ोल्डर के तहत loginComponent.xhtml फ़ाइल बनाएँ ।
5 नीचे बताए अनुसार UserData.java फ़ाइल को संशोधित करें।
6 नीचे बताए अनुसार home.xhtml को संशोधित करें। शेष फाइलों को अपरिवर्तित रखें।
7 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।
8 अंत में, एप्लिकेशन को युद्ध फ़ाइल के रूप में बनाएं और इसे Apache Tomcat Webserver में तैनात करें।
9 अंतिम चरण में नीचे बताए अनुसार उपयुक्त URL का उपयोग करके अपना वेब एप्लिकेशन लॉन्च करें।

loginComponent.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:composite = "http://java.sun.com/jsf/composite">
   
   <composite:interface>
      <composite:attribute name = "usernameLabel" />
      <composite:attribute name = "usernameValue" />
      <composite:attribute name = "passwordLabel" />
      <composite:attribute name = "passwordValue" />
      <composite:attribute name = "loginButtonLabel" />
      <composite:attribute name = "loginButtonAction" 
         method-signature = "java.lang.String login()" />
   </composite:interface>
   
   <composite:implementation>
      <h:form>
         <h:message for = "loginPanel" style = "color:red;" />
         
         <h:panelGrid columns = "2" id = "loginPanel">
            #{cc.attrs.usernameLabel} : 
            <h:inputText id = "username" value = "#{cc.attrs.usernameValue}" />
            #{cc.attrs.passwordLabel} : 
            <h:inputSecret id = "password" value = "#{cc.attrs.passwordValue}" />
         </h:panelGrid>
         
         <h:commandButton action = "#{cc.attrs.loginButtonAction}" 
            value = "#{cc.attrs.loginButtonLabel}"/>
      </h:form>
   </composite:implementation>
</html>

UserData.java

package com.tutorialspoint.test;

import java.io.Serializable;

import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;

@ManagedBean(name = "userData", eager = true)
@SessionScoped
public class UserData implements Serializable {
   private static final long serialVersionUID = 1L;
   private String name;
   private String password;
   
   public String getName() {
      return name;
   }
   
   public void setName(String name) {
      this.name = name;
   }
   
   public String getPassword() {
      return password;
   }
   
   public void setPassword(String password) {
      this.password = password;
   }	
   
   public String login() {
      return "result";
   }	
}

home.xhtml

<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns = "http://www.w3.org/1999/xhtml"   
   xmlns:h = "http://java.sun.com/jsf/html"
   xmlns:f = "http://java.sun.com/jsf/core"
   xmlns:tp = "http://java.sun.com/jsf/composite/tutorialspoint">
   
   <h:head>
      <title>JSF tutorial</title>		     
   </h:head>
   
   <h:body> 
      <h2>Custom Component Example</h2>
      
      <h:form>
      <tp:loginComponent 
         usernameLabel = "Enter User Name: " 
         usernameValue = "#{userData.name}" 
         passwordLabel = "Enter Password: " 
         passwordValue = "#{userData.password}"
         loginButtonLabel = "Login" 
         loginButtonAction = "#{userData.login}" />
      </h:form>
   </h:body>
</html>

एक बार जब आप सभी बदलावों के साथ तैयार हो जाते हैं, तो हमें एप्लिकेशन को संकलित करने और चलाने के लिए जैसा कि हमने JSF में किया था - पहला एप्लिकेशन अध्याय। यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा।