प्रपत्र और सत्यापन घटक
Form Componentउपयोगकर्ता इनपुट के लिए टेपेस्ट्री पेज में एक फॉर्म बनाने के लिए उपयोग किया जाता है। एक फॉर्म में टेक्स्ट फ़ील्ड, दिनांक फ़ील्ड, चेकबॉक्स फ़ील्ड, चयन विकल्प, सबमिट बटन और बहुत कुछ हो सकता है।
यह अध्याय कुछ उल्लेखनीय रूप के घटकों के बारे में विस्तार से बताता है।
चेकबॉक्स घटक
एक चेकबॉक्स घटक का उपयोग दो परस्पर अनन्य विकल्पों के बीच चयन करने के लिए किया जाता है। नीचे दिखाए गए अनुसार चेकबॉक्स का उपयोग करके एक पेज बनाएं -
Checkbox.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.Property;
public class Checkbox {
@Property
private boolean check1;
@Property
private boolean check2;
}
अब, एक संबंधित टेम्पलेट बनाएं Checkbox.tml जैसा कि नीचे दिखाया गया है -
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<h3> checkbox component</h3>
<t:form>
<t:checkbox t:id = "check1"/> I have a bike <br/>
<t:checkbox t:id = "check2"/> I have a car
</t:form>
</html>
यहां, चेकबॉक्स पैरामीटर आईडी संबंधित बूलियन मान से मेल खाता है।
Result - पृष्ठ का अनुरोध करने के बाद, http: // localhost: 8080 / myFirstApplication / चेकबॉक्स यह निम्नलिखित परिणाम उत्पन्न करता है।
TextField घटक
TextField घटक उपयोगकर्ता को पाठ की एक पंक्ति को संपादित करने की अनुमति देता है। पृष्ठ बनाएँText जैसा की नीचे दिखाया गया।
Text.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.Property;
import org.apache.tapestry5.corelib.components.TextField;public class Text {
@Property
private String fname;
@Property
private String lname;
}
फिर, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट बनाएं - Text.tml
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<p> Form application </p>
<body>
<h3> Text field created from Tapestry component </h3>
<t:form>
<table>
<tr>
<td>
Firstname: </td> <td><t:textfield t:id = "fname" />
</td>
<td>Lastname: </td> <td> <t:textfield t:id = "lname" /> </td>
</tr>
</table>
</t:form>
</body>
</html>
यहां, टेक्स्ट पेज में एक संपत्ति शामिल है जिसका नाम है fname तथा lname। घटक आईडी के गुणों द्वारा पहुँचा जाता है।
पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -
http://localhost:8080/myFirstApplication/Text
PasswordField घटक
PasswordField पासवर्ड के लिए एक विशेष टेक्स्ट फ़ील्ड प्रविष्टि है। एक पेज पासवर्ड बनाएं जैसा कि नीचे दिखाया गया है -
Password.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.Property;
import org.apache.tapestry5.corelib.components.PasswordField;
public class Password {
@Property
private String pwd;
}
अब, एक संबंधित टेम्पलेट फ़ाइल बनाएं जैसा कि नीचे दिखाया गया है -
Password.tml
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<p> Form application </p>
<h3> Password field created from Tapestry component </h3>
<t:form>
<table>
<tr>
<td> Password: </td>
<td><t:passwordfield t:id = "pwd"/> </td>
</tr>
</table>
</t:form>
</html>
यहां, PasswordField घटक में पैरामीटर आईडी है, जो संपत्ति को इंगित करता है pwd। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -
http://localhost:8080/myFirstApplication/Password
TextArea घटक
TextArea घटक एक बहु-पंक्ति इनपुट पाठ नियंत्रण है। नीचे दिखाए अनुसार एक पेज TxtArea बनाएँ।
TxtArea.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.Property;
import org.apache.tapestry5.corelib.components.TextArea;
public class TxtArea {
@Property
private String str;
}
फिर, एक संबंधित टेम्पलेट फ़ाइल बनाएं जैसा कि नीचे दिखाया गया है।
TxtArea.tml
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<h3>TextArea component </h3>
<t:form>
<table>
<tr>
<td><t:textarea t:id = "str"/>
</td>
</tr>
</table>
</t:form>
</html>
यहाँ, TextArea घटक पैरामीटर id गुण "str" की ओर इशारा करता है। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -
http://localhost:8080/myFirstApplication/TxtArea**
घटक का चयन करें
चयन घटक में विकल्पों की एक ड्रॉप-डाउन सूची है। एक पेज SelectOption बनाएं जैसा कि नीचे दिखाया गया है।
SelectOption.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.Property;
import org.apache.tapestry5.corelib.components.Select;
public class SelectOption {
@Property
private String color0;
@Property
private Color1 color1;
public enum Color1 {
YELLOW, RED, GREEN, BLUE, ORANGE
}
}
फिर, एक संगत टेम्पलेट बनाएं जो निम्नानुसार है -
SelectOption.tml
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<p> Form application </p>
<h3> select component </h3>
<t:form>
<table>
<tr>
<td> Select your color here: </td>
<td> <select t:type = "select" t:id = "color1"></select></td>
</tr>
</table>
</t:form>
</html>
यहां, चयन घटक के दो पैरामीटर हैं -
Type - संपत्ति का प्रकार एक एनम है।
Id - टेपेस्ट्री संपत्ति "color1" के लिए आईडी अंक।
पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -
http://localhost:8080/myFirstApplication/SelectOption
रेडियोग्रुप घटक
रेडियोग्रुप घटक रेडियो घटकों के लिए एक कंटेनर समूह प्रदान करता है। रेडियो और रेडियोग्रुप घटक किसी वस्तु की संपत्ति को अद्यतन करने के लिए एक साथ काम करते हैं। इस घटक को अन्य रेडियो घटकों के चारों ओर लपेटना चाहिए। जैसा कि नीचे दिखाया गया है एक नया पेज “Radiobutton.java” बनाएं -
Radiobutton.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.PersistenceConstants;
import org.apache.tapestry5.annotations.Persist;
import org.apache.tapestry5.annotations.Property;
public class Radiobutton {
@Property
@Persist(PersistenceConstants.FLASH)
private String value;
}
फिर, एक संबंधित टेम्पलेट फ़ाइल बनाएं जैसा कि नीचे दिखाया गया है -
Radiobutton.tml
<html t:type = "Newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<h3>RadioGroup component </h3>
<t:form>
<t:radiogroup t:id = "value">
<t:radio t:id = "radioT" value = "literal:T" label = "Male" />
<t:label for = "radioT"/>
<t:radio t:id = "radioF" value = "literal:F" label = "Female"/>
<t:label for = "radioF"/>
</t:radiogroup>
</t:form>
</html>
यहां, रेडियोग्रुप घटक आईडी संपत्ति "मूल्य" के साथ बाध्यकारी है। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा।
http://localhost:8080/myFirstApplication/Radiobutton
घटक प्रस्तुत करें
जब उपयोगकर्ता सबमिट बटन पर क्लिक करता है, तो फॉर्म टैग की कार्रवाई सेटिंग में निर्दिष्ट पते पर भेजा जाता है। पृष्ठ बनाएँSubmitComponent जैसा की नीचे दिखाया गया।
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.InjectPage;
public class SubmitComponent {
@InjectPage
private Index page1;
Object onSuccess() {
return page1;
}
}
अब, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट फ़ाइल बनाएं।
SubmitComponent.tml
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<h3>Tapestry Submit component </h3>
<body>
<t:form>
<t:submit t:id = "submit1" value = "Click to go Index"/>
</t:form>
</body>
</html>
यहां, सबमिट करें घटक इंडेक्स पेज पर मूल्य जमा करता है। पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -
http://localhost:8080/myFirstApplication/SubmitComponent
फॉर्म मान्यता
क्लाइंट के सभी आवश्यक डेटा दर्ज करने और फिर फॉर्म जमा करने के बाद सर्वर पर फॉर्म सत्यापन सामान्य रूप से होता है। यदि क्लाइंट द्वारा दर्ज किया गया डेटा गलत था या बस गायब था, तो सर्वर को क्लाइंट को सभी डेटा वापस भेजना होगा और अनुरोध करना होगा कि फॉर्म को सही जानकारी के साथ फिर से सबमिट किया जाए।
हमें सत्यापन की प्रक्रिया को समझने के लिए निम्नलिखित सरल उदाहरण पर विचार करें।
पृष्ठ बनाएँ Validate जैसा की नीचे दिखाया गया।
Validate.java
package com.example.MyFirstApplication.pages;
import org.apache.tapestry5.annotations.Property;
import org.apache.tapestry5.PersistenceConstants;
import org.apache.tapestry5.annotations.Persist;
public class Validate {
@Property
@Persist(PersistenceConstants.FLASH)
private String firstName;
@Property
@Persist(PersistenceConstants.FLASH)
private String lastName;
}
अब, नीचे दिखाए अनुसार एक संबंधित टेम्पलेट फ़ाइल बनाएं।
Validate.tml
<html t:type = "newlayout" title = "About MyFirstApplication"
xmlns:t = "http://tapestry.apache.org/schema/tapestry_5_4.xsd"
xmlns:p = "tapestry:parameter">
<t:form>
<table>
<tr>
<td><t:label for = "firstName"/>:</td>
<td><input t:type = "TextField" t:id = "firstName"
t:validate = "required, maxlength = 7" size = "10"/></td>
</tr>
<tr>
<td><t:label for = "lastName"/>:</td>
<td><input t:type = "TextField" t:id = "lastName"
t:validate = "required, maxLength = 5" size = "10"/></td>
</tr>
</table>
<t:submit t:id = "sub" value =" Form validation"/>
</t:form>
</html>
प्रपत्र सत्यापन के निम्नलिखित महत्वपूर्ण पैरामीटर हैं -
Max - अधिकतम मान को परिभाषित करता है, उदाहरण के लिए = «अधिकतम मूल्य, 20»।
MaxDate- maxDate को परिभाषित करता है, उदाहरण के लिए = «अधिकतम तिथि, 06/09/2013»। इसी तरह, आप MinDate को भी असाइन कर सकते हैं।
MaxLength - उदाहरण के लिए maxLength = «अधिकतम लंबाई, 80»।
Min - न्यूनतम।
MinLength - उदाहरण के लिए न्यूनतम लंबाई = «न्यूनतम लंबाई, 2»।
Email - ईमेल सत्यापन जो या तो मानक ईमेल regexp का उपयोग करता है ^ \ w [._ \ w] * \ w @ \ w [-__ \ w] * \ w \। \ W2,6 $ या कोई नहीं।
पृष्ठ का अनुरोध करना निम्नलिखित परिणाम उत्पन्न करेगा -
http://localhost:8080/myFirstApplication/Validate