अपाचे टेपेस्ट्री - निर्मित घटक

यह अध्याय उन अंतर्निर्मित घटकों के बारे में बताता है, जिनकी टेपेस्ट्री उपयुक्त उदाहरणों के साथ है। टेपेस्ट्री 65 से अधिक निर्मित घटकों का समर्थन करता है। आप कस्टम घटक भी बना सकते हैं। आइए हम कुछ उल्लेखनीय घटकों को विस्तार से कवर करते हैं।

यदि घटक

यदि घटक का उपयोग किसी ब्लॉक को सशर्त रूप से प्रस्तुत करने के लिए किया जाता है। परीक्षण पैरामीटर द्वारा स्थिति की जाँच की जाती है।

पृष्ठ बनाएँ IfSample.java जैसा कि नीचे दिखाया गया है -

package com.example.MyFirstApplication.pages;  

public class Ifsample {
   public String getUser() { 
      return "user1"; 
   } 
}

अब, इस प्रकार एक संबंधित टेम्पलेट फ़ाइल बनाएँ -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
     
   <h3>If-else component example </h3> 
   <t:if test = "user"> 
      Hello ${user} 
      <p:else>
         <h4> You are not a Tapestry user </h4> 
      </p:else> 
   </t:if> 
</html>

पृष्ठ का अनुरोध करना परिणाम को नीचे दिखाए अनुसार प्रस्तुत करेगा।

Result - http: // localhost: 8080 / MyFirstApplication / ifsample

जब तक और प्रतिनिधि घटक न हों

unless componentअगर ऊपर चर्चा की गई थी कि घटक के ठीक विपरीत है। जबकिdelegate componentअपने आप कोई प्रतिपादन नहीं करता है। इसके बजाय, यह आम तौर पर तत्व को ब्लॉक करने के लिए मार्कअप को दर्शाता है। जब तक और यदि घटक डायनामिक सामग्री को सशर्त रूप से स्वैप करने के लिए प्रतिनिधि और ब्लॉक का उपयोग कर सकते हैं।

पृष्ठ बनाएँ Unless.java निम्नलिखित नुसार।

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.Block; 
import org.apache.tapestry5.annotations.Property; 
import org.apache.tapestry5.ioc.annotations.Inject; 
import org.apache.tapestry5.PersistenceConstants; 
import org.apache.tapestry5.annotations.Persist;  

public class Unless { 
   @Property 
   @Persist(PersistenceConstants.FLASH) 
   private String value;  
   @Property 
   private Boolean bool; 
   @Inject 
   Block t, f, n;  
   
   public Block getCase() { 
      if (bool == Boolean.TRUE ) { 
         return t; 
      } else { 
         return f; 
      } 
   }   
}

अब, इस प्रकार एक संबंधित टेम्पलेट फ़ाइल बनाएँ -

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
  
   <h4> Delegate component </h4> 
   <div class = "div1"> 
      <t:delegate to = "case"/> 
   </div> 
   <h4> If-Unless component </h4>  
   
   <div class = "div1"> 
      <t:if test = "bool"> 
         <t:delegate to = "block:t"/> 
      </t:if> 
      <t:unless test = "bool"> 
         <t:delegate to = "block:notT"/> 
      </t:unless> 
   </div>  
   
   <t:block id = "t"> 
      bool == Boolean.TRUE. 
   </t:block> 
   
   <t:block id = "notT"> 
      bool = Boolean.FALSE. 
   </t:block> 
   
   <t:block id = "f"> 
      bool == Boolean.FALSE. 
   </t:block> 
</html>

पृष्ठ का अनुरोध करना परिणाम को नीचे दिखाए अनुसार प्रस्तुत करेगा।

Result - http: // localhost: 8080 / MyFirstApplication / जब तक

पाश घटक

लूप घटक एक संग्रह आइटम पर लूप करने के लिए मूल घटक है और शरीर को हर मूल्य / पुनरावृत्ति के लिए प्रस्तुत करता है।

नीचे दिखाए अनुसार एक लूप पेज बनाएं -

Loop.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class Loop { 
   @Property 
   private int i; 
}

फिर, इसी टेम्पलेट Loop.tml बनाएँ

Loop.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <p>This is sample parameter rendering example...</p> 
   <ol>
      <li t:type = "loop" source = "1..5" value = "var:i">${var:i}</li> 
   </ol> 
</html>

लूप घटक में निम्नलिखित दो पैरामीटर हैं -

  • source- संग्रह स्रोत। 1… 5 एक संपत्ति विस्तार है जिसका उपयोग एक निर्दिष्ट सीमा के साथ एक सरणी बनाने के लिए किया जाता है।

  • var- रेंडर चर। टेम्पलेट के शरीर में वर्तमान मूल्य को प्रस्तुत करने के लिए उपयोग किया जाता है।

पृष्ठ का अनुरोध करना परिणाम को नीचे दिखाए अनुसार प्रस्तुत करेगा -

पेजलिंक घटक

PageLink घटक का उपयोग एक पृष्ठ को एक पृष्ठ से दूसरे पृष्ठ से जोड़ने के लिए किया जाता है। नीचे एक PageLink परीक्षण पृष्ठ बनाएँ -PageLink.java

package com.example.MyFirstApplication.pages;  
   public class PageLink { 
}

फिर, जैसा नीचे दिखाया गया है, उसी अनुरूप फ़ाइल बनाएँ -

PageLink.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <body> 
      <h3><u>Page Link</u> </h3> 
      <div class = "page"> 
         <t:pagelink page = "Index">Click here to navigate Index page</t:pagelink>
         <br/> 
      </div> 
   </body> 
   
</html>

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

Result - http: // localhost: 8080 / myFirstApplication / pagelink

EventLink घटक

EventLink घटक URL के माध्यम से ईवेंट नाम और संबंधित पैरामीटर भेजता है। जैसा कि नीचे दिखाया गया है एक EventLink पेज क्लास बनाएँ।

EventsLink.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class EventsLink { 
   @Property 
   private int x; 
   void onActivate(int count) { 
      this.x = x; 
   } 
   int onPassivate() { 
      return x; 
   } 
   void onAdd(int value) { 
      x += value; 
   }   
}

फिर, इस प्रकार एक "EventLink" टेम्पलेट फ़ाइल बनाएँ -

EventsLink.tml

<html t:type = "newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <h3> Event link example </h3> 
   AddedCount = ${x}. <br/> 
   <t:eventlink t:event = "add" t:context = "literal:1">
      Click here to add count
   </t:eventlink><br/>  
</html>

EventLink के निम्नलिखित दो पैरामीटर हैं -

  • Event- EventLink घटक में चालू होने वाली घटना का नाम। डिफ़ॉल्ट रूप से, यह घटक की आईडी को इंगित करता है।

  • Context- यह एक वैकल्पिक पैरामीटर है। यह लिंक के लिए संदर्भ को परिभाषित करता है।

Result - http: // localhost: 8080 / myFirstApplication / EventsLink

गणना मूल्य पर क्लिक करने के बाद, पृष्ठ URL में ईवेंट का नाम प्रदर्शित करेगा जैसा कि निम्न आउटपुट स्क्रीनशॉट में दिखाया गया है।

ActionLink घटक

ActionLink घटक EventLink घटक के समान है, लेकिन यह केवल लक्ष्य घटक आईडी भेजता है। डिफ़ॉल्ट ईवेंट नाम क्रिया है।

नीचे दिखाए अनुसार एक पेज “ActivationLinks.java” बनाएं,

ActivationLinks.java

package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.Property;  
public class ActivationLinks {  
   @Property 
   private int x;  
   void onActivate(int count) { 
      this.x = x; 
   }  
   int onPassivate() { 
      return x; 
   } 
   void onActionFromsub(int value) { 
      x -= value; 
   } 
}

अब, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट फ़ाइल बनाएं -

ActivationLinks.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <div class = "div1"> 
      Count = ${count}. <br/> 
      <t:actionlink t:id = "sub" t:context = "literal:1">
         Decrement
      </t:actionlink><br/> 
   </div> 
   
</html>

यहां ही OnActionFromSub एक्शनलिंक घटक पर क्लिक करने पर विधि को बुलाया जाएगा।

Result - http: // localhost: 8080 / myFirstApplication / ActivationsLink

चेतावनी घटक

एक चेतावनी संवाद बॉक्स का उपयोग ज्यादातर उपयोगकर्ताओं को चेतावनी संदेश देने के लिए किया जाता है। उदाहरण के लिए, यदि इनपुट फ़ील्ड में कुछ अनिवार्य पाठ की आवश्यकता होती है, लेकिन उपयोगकर्ता कोई इनपुट प्रदान नहीं करता है, तो सत्यापन के एक भाग के रूप में, आप चेतावनी संदेश देने के लिए अलर्ट बॉक्स का उपयोग कर सकते हैं।

निम्नलिखित कार्यक्रम में दिखाए गए अनुसार एक पृष्ठ "अलर्ट" बनाएं।

Alerts.java

package com.example.MyFirstApplication.pages;  

public class Alerts { 
   public String getUser() { 
      return "user1"; 
   } 
}

फिर, इस प्रकार एक संबंधित टेम्पलेट फ़ाइल बनाएं -

Alerts.tml

<html t:type = "Newlayout" title = "About MyFirstApplication" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"  
   xmlns:p = "tapestry:parameter">  
   
   <h3>Alerts</h3> 
   <div class = "alert alert-info"> 
      <h5> Welcome ${user} </h5> 
   </div>
   
</html>

अलर्ट में तीन गंभीरता स्तर होते हैं, जो हैं -

  • Info
  • Warn
  • Error

उपरोक्त टेम्पलेट एक सूचना चेतावनी का उपयोग करके बनाया गया है। इसे के रूप में परिभाषित किया गया हैalert-info। आप आवश्यकता के आधार पर अन्य गंभीरता बना सकते हैं।

पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -

http://localhost:8080/myFirstApplication/Alerts