अपाचे टेपेस्ट्री - घटक

जैसा कि पहले चर्चा की गई है, घटक और पृष्ठ समान हैं सिवाय इसके कि पृष्ठ मूल घटक है और इसमें एक या अधिक बाल घटक शामिल हैं। घटक हमेशा एक पृष्ठ के अंदर रहते हैं और पृष्ठ की लगभग सभी गतिशील कार्यक्षमता करते हैं।

टेपेस्ट्री घटकों के साथ जटिल ग्रिड कार्यक्षमता के लिए एक सरल HTML लिंक प्रदान करता है interactive AJAX। एक घटक दूसरे घटक को भी शामिल कर सकता है। टेपेस्ट्री घटकों में निम्नलिखित आइटम होते हैं -

  • Component Class - घटक का मुख्य जावा वर्ग।

  • XML Template- XML ​​टेम्पलेट पेज टेम्पलेट के समान है। घटक वर्ग अंतिम आउटपुट के रूप में टेम्पलेट को प्रस्तुत करता है। कुछ घटकों में टेम्पलेट नहीं हो सकते हैं। इस मामले में, आउटपुट का उपयोग घटक वर्ग द्वारा ही किया जाएगाMarkupWriter कक्षा।

  • Body- पेज टेम्प्लेट के अंदर निर्दिष्ट घटक में कस्टम मार्कअप हो सकता है और इसे "घटक निकाय" कहा जाता है। यदि घटक टेम्पलेट है<body />तत्व, तब <शरीर /> तत्व को घटक के शरीर द्वारा प्रतिस्थापित किया जाएगा। यह पहले XML टेम्प्लेट अनुभाग में चर्चा किए गए लेआउट के समान है।

  • Rendering - प्रतिपादन एक ऐसी प्रक्रिया है जो XML टेम्पलेट और घटक के शरीर को घटक के वास्तविक आउटपुट में बदल देती है।

  • Parameters - घटक और पृष्ठों के बीच संचार बनाने और इस तरह उनके बीच डेटा पास करने के लिए उपयोग किया जाता है।

  • Events- इसके कंटेनर / माता-पिता (पृष्ठ या किसी अन्य घटक) के घटकों से कार्यक्षमता को हटाता है। यह पृष्ठ नेविगेशन उद्देश्य में बड़े पैमाने पर उपयोग किया जाता है।

प्रतिपादन

एक घटक का प्रतिपादन पूर्व-परिभाषित चरणों की एक श्रृंखला में किया जाता है। घटक प्रणाली के प्रत्येक चरण में घटक वर्ग में कन्वेंशन या एनोटेशन द्वारा परिभाषित एक संबंधित विधि होनी चाहिए।

// Using annotaion 
@SetupRender 
void initializeValues() { 
   // initialize values 
}

// using convention 
boolean afterRender() { 
   // do logic 
   return true; 
}

चरण, इसकी विधि का नाम और इसके एनोटेशन नीचे सूचीबद्ध हैं।

टिप्पणी डिफ़ॉल्ट विधि नाम
@SetupRender setupRender ()
@BeginRender beginRender ()
@BeforeRenderTemplate beforeRenderTemplate ()
@BeforeRenderBody beforeRenderBody ()
@AfterRenderBody afterRenderBody ()
@AfterRenderTemplate afterRenderTemplate ()
@AfterRender afterRender ()
@CleanupRender cleanupRender ()

प्रत्येक चरण का एक विशिष्ट उद्देश्य होता है और वे इस प्रकार हैं -

SetupRender

SetupRender किकिंग प्रक्रिया को शुरू करता है। यह आमतौर पर घटक के मापदंडों को स्थापित करता है।

BeginRender

BeginRender घटक को प्रस्तुत करना शुरू करता है। यह आमतौर पर कंपोनेंट के स्टार्ट / स्टार्ट टैग को प्रस्तुत करता है।

BeforeRenderTemplate

पहले XML टेम्प्लेट को सजाने के लिए RenderTemplate का उपयोग किया जाता है, टेम्प्लेट के चारों ओर विशेष मार्कअप जोड़ते हैं। यह टेम्प्लेट रेंडरिंग को छोड़ने का विकल्प भी प्रदान करता है।

BeforeRenderBody

पहलेRenderTemplate घटक के शरीर तत्व के प्रतिपादन को छोड़ने के लिए एक विकल्प प्रदान करता है।

AfterRenderBody

AfterRenderBody घटक के शरीर प्रदान करने के बाद कहा जाएगा।

AfterRenderTemplate

AfterRenderTemplate घटक के टेम्पलेट प्रदान किए जाने के बाद कहा जाएगा।

AfterRender

आफ्टरएंडर बिगिनर का समकक्ष है और आमतौर पर क्लोज टैग को प्रस्तुत करता है।

CleanupRender

CleanupRender SetupRender का प्रतिरूप है। यह रेंडरिंग प्रक्रिया के दौरान बनाए गए सभी ऑब्जेक्ट को रिलीज़ / डिस्पोज़ करता है।

प्रतिपादन चरणों का प्रवाह केवल आगे नहीं है। यह चरण के वापसी मूल्य के आधार पर चरणों के बीच में जाता है।

उदाहरण के लिए, अगर SetupRender विधि गलत है, तो रेंडरिंग क्लीनअपेंडर चरण में और इसके विपरीत। विभिन्न चरणों के बीच प्रवाह की स्पष्ट समझ पाने के लिए, नीचे दिए गए आरेख में प्रवाह की जांच करें।

सरल घटक

आइए हम एक सरल घटक बनाते हैं, हैलो जिसका आउटपुट संदेश "हैलो, टेपेस्ट्री" के रूप में होगा। हैलो घटक और उसके टेम्पलेट का कोड निम्नलिखित है।

package com.example.MyFirstApplication.components;  
public class Hello {  
}
<html  
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
  
   <div> 
      <p>Hello, Tapestry (from component).</p> 
   </div> 
  
</html>

हैलो घटक को पेज टेम्पलेट में कहा जा सकता है -

<html title = "Hello component test page" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
<t:hello />  
</html>

इसी प्रकार, घटक नीचे दिखाए गए अनुसार टेम्पलेट के बजाय मार्कअपविटर का उपयोग करके समान आउटपुट प्रस्तुत कर सकता है।

package com.example.MyFirstApplication.components; 
  
import org.apache.tapestry5.MarkupWriter; 
import org.apache.tapestry5.annotations.BeginRender;   

public class Hello { 
   @BeginRender 
   void renderMessage(MarkupWriter writer) { 
      writer.write("<p>Hello, Tapestry (from component)</p>"); 
   } 
}

आइए हम घटक टेम्पलेट को बदलते हैं और नीचे कोड कोड में दिखाए गए <body /> तत्व को शामिल करते हैं।

<html>  
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <div> 
      <t:body /> 
   </div> 
</html>

अब, पृष्ठ टेम्पलेट में घटक मार्कअप में शरीर शामिल हो सकता है जैसा कि नीचे दिखाया गया है।

<html title = "Hello component test page" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <t:hello> 
      <p>Hello, Tapestry (from page).</p> 
   </t:hello> 
</html>

आउटपुट निम्नानुसार होगा -

<html> 
   <div> 
      <p>Hello, Tapestry (from page).</p> 
   </div> 
</html>

पैरामीटर

इन मापदंडों का प्राथमिक उद्देश्य घटक के क्षेत्र और पेज की एक संपत्ति / संसाधन के बीच संबंध बनाना है। मापदंडों, घटक और इसके संबंधित पृष्ठ का उपयोग करते हुए एक दूसरे के बीच डेटा संवाद और हस्तांतरण। यह कहा जाता हैTwo Way Data Binding

उदाहरण के लिए, उपयोगकर्ता प्रबंधन पृष्ठ में उम्र का प्रतिनिधित्व करने के लिए उपयोग किया जाने वाला एक टेक्स्टबॉक्स घटक पैरामीटर के माध्यम से अपना प्रारंभिक मूल्य (डेटाबेस में उपलब्ध) प्राप्त करता है। फिर से, उपयोगकर्ता की उम्र को अपडेट करने और वापस जमा करने के बाद, घटक उसी पैरामीटर के माध्यम से अपडेट की गई आयु को वापस भेज देगा।

घटक वर्ग में एक नया पैरामीटर बनाने के लिए, एक क्षेत्र घोषित करें और निर्दिष्ट करें @Parameterएनोटेशन। इस @ पैरामीटर में दो वैकल्पिक तर्क हैं, जो हैं -

  • required- पैरामीटर को अनिवार्य बनाता है। टेपेस्ट्री अपवाद प्रदान करता है अगर यह प्रदान नहीं किया जाता है।

  • value - पैरामीटर का डिफ़ॉल्ट मान निर्दिष्ट करता है।

पैरामीटर को पेज टेम्प्लेट में घटक टैग की विशेषताओं के रूप में निर्दिष्ट किया जाना चाहिए। बाइंडिंग एक्सप्रेशन / एक्सपेंशन का उपयोग करके विशेषताओं का मूल्य निर्दिष्ट किया जाना चाहिए, जिसकी चर्चा हमने पहले अध्यायों में की थी। विस्तार के कुछ जो हमने पहले सीखा था -

  • Property expansion (prop:«val») - पेज क्लास की संपत्ति से डेटा प्राप्त करें।

  • Message expansion (message:«val») - index.properties फ़ाइल में परिभाषित कुंजी से डेटा प्राप्त करें।

  • Context expansion (context:«val») - वेब संदर्भ फ़ोल्डर / src / main / webapp से डेटा प्राप्त करें।

  • Asset expansion (asset:«val») - जार फ़ाइल, / मेटा-इन / परिसंपत्तियों में एम्बेडेड संसाधनों से डेटा प्राप्त करें।

  • Symbol expansion (symbol:«val») - AppModule.javafile में परिभाषित प्रतीकों से डेटा प्राप्त करें।

टेपेस्ट्री के कई और उपयोगी विस्तार हैं, जिनमें से कुछ नीचे दिए गए हैं -

  • Literal expansion (literal:«val») - एक शाब्दिक स्ट्रिंग।

  • Var expansion (var:«val») - घटक के एक रेंडर चर को पढ़ने या अद्यतन करने की अनुमति दें।

  • Validate expansion (validate:«val»)- किसी विशेष स्ट्रिंग का उपयोग किसी वस्तु के सत्यापन नियम को निर्दिष्ट करने के लिए किया जाता है। उदाहरण के लिए, मान्य करें: आवश्यक, minLength = 5।

  • Translate (translate:«val») - इनपुट सत्यापन में ट्रांसलेटर क्लास (क्लाइंट-साइड को सर्वर-साइड प्रतिनिधित्व में परिवर्तित करना) निर्दिष्ट करने के लिए उपयोग किया जाता है।

  • Block (block:«val») - टेम्पलेट के भीतर ब्लॉक तत्व की आईडी।

  • Component (component:«val») - टेम्पलेट के भीतर एक अन्य घटक की आईडी।

उपरोक्त सभी विस्तार केवल संपत्ति के विस्तार और वार विस्तार को छोड़कर पढ़े जाते हैं। वे पृष्ठ के साथ डेटा का आदान-प्रदान करने के लिए घटक द्वारा उपयोग किया जाता है। विशेषता मान के रूप में विस्तार का उपयोग करते समय,${...}उपयोग नहीं किया जाना चाहिए। इसके बजाय सिर्फ डॉलर के बिना विस्तार का उपयोग करें और प्रतीकों का ब्योरा दें।

पैरामीटर का उपयोग करना

हमें नमस्कार घटक को गतिशील रूप से एक संदेश जोड़कर रेंडर करने के लिए एक नया घटक, HelloWithParameter बनाते हैं name घटक वर्ग में पैरामीटर और घटक टेम्पलेट और पेज टेम्पलेट को तदनुसार बदलना।

  • एक नया घटक वर्ग बनाएँ HelloWithParameter.java

  • एक निजी फ़ील्ड जोड़ें और इसे नाम दें @Parameterएनोटेशन। इसे अनिवार्य बनाने के लिए आवश्यक तर्क का उपयोग करें।

@Parameter(required = true) 
private String name;
  • परिणाम के साथ एक निजी फ़ील्ड जोड़ें @Properyएनोटेशन। परिणाम संपत्ति का उपयोग घटक टेम्पलेट में किया जाएगा। घटक टेम्पलेट के साथ एनोटेट किए गए फ़ील्ड तक पहुंच नहीं है@Parameter और केवल उन क्षेत्रों तक पहुँचने में सक्षम हैं जिनके साथ एनोटेट किया गया है @Property। घटक टेम्प्लेट में उपलब्ध चर को रेंडर वेरिएबल्स कहा जाता है।

@Property 
 private String result;
  • एक RenderBody विधि जोड़ें और नाम पैरामीटर से परिणाम संपत्ति में मूल्य की प्रतिलिपि बनाएँ।

@BeginRender 
void initializeValues() { 
   result = name; 
}
  • एक नया घटक टेम्पलेट जोड़ें HelloWithParamter.tml और संदेश को प्रस्तुत करने के लिए परिणाम संपत्ति का उपयोग करें।

<div> Hello, ${result} </div>
  • परीक्षण पृष्ठ (testhello.java) में एक नई संपत्ति, उपयोगकर्ता नाम जोड़ें।

public String getUsername() { 
   return "User1"; 
}
  • पृष्ठ टेम्पलेट में नए बनाए गए घटक का उपयोग करें और के नाम पैरामीटर में उपयोगकर्ता नाम संपत्ति सेट करें HelloWithParameter घटक।

<t:helloWithParameter name = "username" />

पूरी लिस्टिंग इस प्रकार है -

package com.example.MyFirstApplication.components;  

import org.apache.tapestry5.annotations.*;  
public class HelloWithParameter { 
   @Parameter(required = true) 
   private String name; 
     
   @Property 
   private String result; 
   
   @BeginRender 
   void initializeValues() { 
      result = name; 
   } 
}
<html  
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   
   <div> Hello, ${result} </div> 
  
</html>
package com.example.MyFirstApplication.pages;  

import org.apache.tapestry5.annotations.*;  
public class TestHello { 
   public String getUsername() { 
      return "User1"; 
   } 
}
<html title = "Hello component test page" 
   xmlns:t = "https://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter"> 
   <t:helloWithParameter name = "username" />
   
</html>

परिणाम इस प्रकार होगा -

<div> Hello, User1 </div>

उन्नत पैरामीटर

पिछले अध्यायों में, हमने विश्लेषण किया कि कस्टम घटक में एक साधारण पैरामीटर कैसे बनाया और उपयोग किया जाए। एक उन्नत पैरामीटर में पूर्ण मार्कअप भी हो सकता है। इस स्थिति में, मार्कअप को घटक टैग के अंदर निर्दिष्ट किया जाना चाहिए जैसे पृष्ठ टेम्पलेट में उप-भाग। अंतर्निहित घटक में सफलता और विफलता दोनों स्थितियों के लिए मार्कअप है। सफलता के लिए मार्कअप घटक टैग के शरीर के रूप में निर्दिष्ट किया गया है और विफलता का मार्कअप एक का उपयोग करके निर्दिष्ट किया गया हैelseparameter

आइए देखते हैं कि कैसे उपयोग करना है ifघटक। यदि घटक के दो पैरामीटर हैं -

  • test - सरल संपत्ति आधारित पैरामीटर।

  • Else - उन्नत पैरामीटर वैकल्पिक मार्कअप को निर्दिष्ट करने के लिए उपयोग किया जाता है, अगर स्थिति विफल हो जाती है

टेपेस्ट्री निम्नलिखित तर्क का उपयोग करके परीक्षण संपत्ति के मूल्य की जांच करेगा और सही या गलत लौटाएगा। यह कहा जाता हैType Coercion, एक प्रकार की वस्तु को उसी प्रकार की सामग्री के साथ दूसरे प्रकार में बदलने का तरीका।

  • यदि डेटा प्रकार है String, "सही" यदि गैर-रिक्त है और शाब्दिक स्ट्रिंग "गलत" (असंवेदनशील) नहीं है।

  • यदि डेटा प्रकार है Number, सत्य अगर गैर शून्य।

  • यदि डेटा प्रकार है Collection, सच्चा अगर गैर-खाली है।

  • यदि डेटा प्रकार है Object, सच (जब तक यह अशक्त नहीं है)।

यदि स्थिति गुजरती है, तो घटक अपने शरीर को प्रदान करता है; अन्यथा, यह दूसरे पैरामीटर के शरीर का प्रतिपादन करता है।

पूरी लिस्टिंग इस प्रकार है -

package com.example.MyFirstApplication.pages; 
public class TestIf { 
   public String getUser() { 
      return "User1"; 
   } 
}

<html title = "If Test Page" 
   xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd" 
   xmlns:p = "tapestry:parameter">  
   
   <body> 
      <h1>Welcome!</h1>  
      <t:if test = "user"> 
         Welcome back, ${user} 
         <p:else>
            Please <t:pagelink page = "login">Login</t:pagelink>  
         </p:else> 
      </t:if>
   </body>
   
</html>

घटक घटनाओं / पृष्ठ नेविगेशन

टेपेस्ट्री आवेदन एक है collection of Pagesआपस में बातचीत करना। अब तक, हमने सीखा है कि उनके बीच किसी भी संचार के बिना व्यक्तिगत पृष्ठ कैसे बनाएं। एक घटक ईवेंट का प्राथमिक उद्देश्य सर्वर-साइड ईवेंट्स का उपयोग करके पृष्ठों (पृष्ठों के भीतर भी) के बीच इंटरैक्शन प्रदान करना है। अधिकांश घटक ईवेंट क्लाइंट-साइड ईवेंट से उत्पन्न होते हैं।

उदाहरण के लिए, जब कोई उपयोगकर्ता किसी पृष्ठ में एक लिंक पर क्लिक करता है, तो टेपेस्ट्री उसी पृष्ठ को स्वयं को लक्ष्य जानकारी के बजाय लक्ष्य पृष्ठ पर कॉल करेगा और सर्वर साइड ईवेंट को उठाएगा। टेपेस्ट्री पेज ईवेंट को कैप्चर करेगा, टारगेट जानकारी को प्रोसेस करेगा और टारगेट पेज पर एक सर्वर साइड रिडायरेक्शन करेगा।

टेपेस्ट्री इस प्रकार है Post/Redirect/Get (RPG) design patternपेज नेविगेशन के लिए। आरपीजी में, जब कोई उपयोगकर्ता एक फ़ॉर्म सबमिट करके पोस्ट अनुरोध करता है, तो सर्वर पोस्ट किए गए डेटा को संसाधित करेगा, लेकिन सीधे प्रतिक्रिया वापस नहीं करता है। इसके बजाय, यह एक ग्राहक-पृष्ठ को दूसरे पृष्ठ पर रीडायरेक्ट करेगा, जो परिणाम को आउटपुट करेगा। एक आरपीजी पैटर्न का उपयोग ब्राउज़र बैक बटन, ब्राउज़र रिफ्रेश बटन आदि के माध्यम से डुप्लिकेट फॉर्म सबमिशन को रोकने के लिए किया जाता है, टेपेस्ट्री निम्नलिखित दो प्रकार के अनुरोध प्रदान करके आरपीजी पैटर्न प्रदान करता है।

  • Component Event Request- इस प्रकार का अनुरोध पृष्ठ में किसी विशेष घटक को लक्षित करता है और घटक के भीतर घटनाओं को बढ़ाता है। यह अनुरोध केवल एक पुनर्निर्देशन करता है और प्रतिक्रिया का उत्पादन नहीं करता है।

  • Render Request - इन प्रकार के अनुरोध एक पृष्ठ को लक्षित करते हैं और ग्राहक को प्रतिक्रिया वापस देते हैं।

घटक घटनाओं और पृष्ठ नेविगेशन को समझने के लिए, हमें टेपेस्ट्री अनुरोध के URL पैटर्न को जानना होगा। दोनों प्रकार के अनुरोधों का URL पैटर्न निम्नानुसार है -

  • Component Event Requests -

/<<page_name_with_path>>.<<component_id|event_id>>/<<context_information>>
  • Render Request -

/<<page_name_with_path>>/<<context_information>>

URL पैटर्न के कुछ उदाहरण हैं -

  • इंडेक्स पेज द्वारा अनुरोध किया जा सकता है https://«domain»/«app»/index

  • यदि अनुक्रमणिका पृष्ठ उप-फ़ोल्डर व्यवस्थापक के अंतर्गत उपलब्ध है, तो इसके द्वारा अनुरोध किया जा सकता है https://«domain»/«app»/admin/index

  • यदि उपयोगकर्ता क्लिक करता है ActionLink component साथ में id test इंडेक्स पेज में, तब URL होगा https://«domain»/«app»/index.test

आयोजन

डिफ़ॉल्ट रूप से, टेपेस्ट्री बढ़ जाती है OnPassivate तथा OnActivateसभी अनुरोधों के लिए घटनाओं। घटक घटना अनुरोध प्रकार के लिए, टेपेस्ट्री घटक के आधार पर अतिरिक्त एक या अधिक घटनाओं को बढ़ाता है। ActionLink घटक एक्शन ईवेंट को बढ़ाता है, जबकि एक फॉर्म कंपोनेंट कई ईवेंट जैसे कि बढ़ाता हैValidate, Success, आदि।,

घटनाओं को पेज क्लास में संबंधित विधि हैंडलर का उपयोग करके संभाला जा सकता है। विधि हैंडलर या तो विधि नामकरण सम्मेलन के माध्यम से या के माध्यम से बनाया जाता है@OnEventएनोटेशन। विधि नामकरण सम्मेलन का प्रारूप हैOn«EventName»From«ComponentId»

एक्शनलिंक के एक्शन इवेंट के साथ id test निम्नलिखित में से किसी एक विधि द्वारा नियंत्रित किया जा सकता है -

void OnActionFromTest() { 
}  
@OnEvent(component = "test", name = "action") 
void CustomFunctionName() { 
}

यदि विधि के नाम में कोई विशेष घटक नहीं है, तो विधि को मेल खाने वाली घटनाओं के साथ सभी घटक के लिए बुलाया जाएगा।

void OnAction() { 
}

OnPassivate और OnActivate Event

OnAassivate इवेंट हैंडलर के लिए संदर्भ जानकारी प्रदान करने के लिए OnPassivate का उपयोग किया जाता है। सामान्य तौर पर, टेपेस्ट्री संदर्भ जानकारी प्रदान करती है और इसे ऑनएक्टिनेटिव हैंडलर में एक तर्क के रूप में इस्तेमाल किया जा सकता है।

उदाहरण के लिए, यदि संदर्भ जानकारी 3 प्रकार की है, तो OnActivate घटना को कहा जा सकता है -

void OnActivate(int id) { 
}

कुछ परिदृश्य में, संदर्भ जानकारी उपलब्ध नहीं हो सकती है। इस स्थिति में, हम ऑनपेसिनेट इवेंट हैंडलर के माध्यम से ऑनएक्टिव इवेंट हैंडलर को संदर्भ जानकारी प्रदान कर सकते हैं। OnPassivate इवेंट हैंडलर का रिटर्न प्रकार OnActivate इवेंट हैंडलर के तर्क के रूप में उपयोग किया जाना चाहिए।

int OnPassivate() { 
   int id = 3; 
   return id; 
} 
void OnActivate(int id) { 
}

इवेंट हैंडलर रिटर्न वैल्यूज़

टेपेस्ट्री ईवेंट हैंडलर के रिटर्न वैल्यू के आधार पर पेज पुनर्निर्देशन जारी करती है। इवेंट हैंडलर को निम्न में से किसी एक मान को वापस करना चाहिए।

  • Null Response- शून्य मान लौटाता है। टेपेस्ट्री वर्तमान पृष्ठ URL का निर्माण करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेजेगी।

public Object onAction() { 
   return null; 
}
  • String Response- स्ट्रिंग मान लौटाता है। टेपेस्ट्री वैल्यू से मेल खाते पेज का URL बनाएगी और क्लाइंट को रीडायरेक्ट के रूप में भेजेगी।

public String onAction() { 
   return "Index"; 
}
  • Class Response- एक पृष्ठ वर्ग देता है। टेपेस्ट्री लौटे पेज क्लास के यूआरएल का निर्माण करेगा और क्लाइंट को रीडायरेक्ट के रूप में भेजेगा।

public Object onAction() { 
   return Index.class 
}
  • Page Response- @InjectPage के साथ एनोटेट किया गया फ़ील्ड लौटाता है। टेपेस्ट्री इंजेक्ट किए गए पृष्ठ के URL का निर्माण करेगा और क्लाइंट को रीडायरेक्ट के रूप में भेजेगा।

@InjectPage 
private Index index;  

public Object onAction(){ 
   return index; 
}
  • HttpError- HTTPError ऑब्जेक्ट लौटाता है। टेपेस्ट्री क्लाइंट साइड HTTP त्रुटि जारी करेगा।

public Object onAction(){ 
   return new HttpError(302, "The Error message); 
}
  • Link Response- सीधे एक लिंक उदाहरण देता है। टेपेस्ट्री लिंक ऑब्जेक्ट से URL का निर्माण करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेजेगी।

  • Stream Response - लौटता है StreamResponseवस्तु। टेपेस्ट्री सीधे क्लाइंट ब्राउज़र को प्रतिक्रिया के रूप में स्ट्रीम भेज देगा। इसका उपयोग सीधे रिपोर्ट और चित्र बनाने और क्लाइंट को भेजने के लिए किया जाता है।

  • Url Response - लौटता है java.net.URLवस्तु। टेपेस्ट्री ऑब्जेक्ट से संबंधित URL प्राप्त करेगी और क्लाइंट को रीडायरेक्ट के रूप में भेज देगी।

  • Object Response- ऊपर निर्दिष्ट मूल्यों के अलावा किसी भी मान देता है। टेपेस्ट्री एक त्रुटि उठाएगी।

घटना प्रसंग

सामान्य तौर पर, ईवेंट हैंडलर तर्कों का उपयोग करके संदर्भ जानकारी प्राप्त कर सकता है। उदाहरण के लिए, यदि संदर्भ जानकारी 3 प्रकार की है, तो ईवेंट हैंडलर होगा -

Object onActionFromTest(int id) {  
}

टेपेस्ट्री संदर्भ जानकारी को ठीक से संभालती है और इसे तर्कों के माध्यम से प्रदान करती है। कभी-कभी, टेपेस्ट्री प्रोग्रामिंग की जटिलता के कारण इसे ठीक से संभालने में सक्षम नहीं हो सकता है। उस समय, हम पूरी संदर्भ जानकारी प्राप्त कर सकते हैं और स्वयं को संसाधित कर सकते हैं।

Object onActionFromEdit(EventContext context) { 
   if (context.getCount() > 0) { 
      this.selectedId = context.get(0); 
   } else { 
      alertManager.warn("Please select a document."); 
      return null; 
   } 
}