वैलिडेशन
परिचय
Nylo Website v7 FormValidator क्लास के आधार पर एक वैलिडेशन सिस्टम प्रदान करता है। आप check() मेथड का उपयोग करके पेजों के अंदर डेटा वैलिडेट कर सकते हैं, या स्टैंडअलोन और फ़ील्ड-लेवल वैलिडेशन के लिए सीधे FormValidator का उपयोग कर सकते हैं।
// Validate data in a NyPage/NyState using check()
check((validate) {
validate.that('user@example.com').email();
validate.that('Anthony')
.capitalized()
.maxLength(50);
}, onSuccess: () {
print("All validations passed!");
});
// FormValidator with form fields
Field.text("Email", validator: FormValidator.email())
check() के साथ डेटा वैलिडेट करना
किसी भी NyPage के अंदर, डेटा वैलिडेट करने के लिए check() मेथड का उपयोग करें। यह एक कॉलबैक स्वीकार करता है जो वैलिडेटर्स की सूची प्राप्त करता है। डेटा जोड़ने और नियम चेन करने के लिए .that() का उपयोग करें:
class _RegisterPageState extends NyPage<RegisterPage> {
void handleForm() {
check((validate) {
validate.that(_emailController.text, label: "Email").email();
validate.that(_passwordController.text, label: "Password")
.notEmpty()
.password(strength: 2);
}, onSuccess: () {
// All validations passed
_submitForm();
}, onValidationError: (FormValidationResponseBag bag) {
// Validation failed
print(bag.firstErrorMessage);
});
}
}
check() कैसे काम करता है
check()एक खालीList<FormValidator>बनाता है- आपका कॉलबैक
.that(data)का उपयोग करके सूची में डेटा के साथ एक नयाFormValidatorजोड़ता है - प्रत्येक
.that()एकFormValidatorरिटर्न करता है जिस पर आप नियम चेन कर सकते हैं - कॉलबैक के बाद, सूची में प्रत्येक वैलिडेटर की जाँच की जाती है
- परिणाम एक
FormValidationResponseBagमें एकत्र किए जाते हैं
एकाधिक फ़ील्ड्स वैलिडेट करना
check((validate) {
validate.that(_nameController.text, label: "Name").notEmpty().capitalized();
validate.that(_emailController.text, label: "Email").email();
validate.that(_phoneController.text, label: "Phone").phoneNumberUs();
validate.that(_ageController.text, label: "Age").numeric().minValue(18);
}, onSuccess: () {
_submitForm();
});
वैकल्पिक label पैरामीटर एक मानव-पठनीय नाम सेट करता है जो एरर मैसेज में उपयोग किया जाता है (उदा. "The Email must be a valid email address.")।
वैलिडेशन रिज़ल्ट्स
check() मेथड एक FormValidationResponseBag (List<FormValidationResult> की एक सूची) रिटर्न करता है, जिसे आप सीधे भी निरीक्षण कर सकते हैं:
FormValidationResponseBag bag = check((validate) {
validate.that(_emailController.text, label: "Email").email();
validate.that(_passwordController.text, label: "Password")
.password(strength: 1);
});
if (bag.isValid) {
print("All valid!");
} else {
// Get the first error message
String? error = bag.firstErrorMessage;
print(error);
// Get all failed results
List<FormValidationResult> errors = bag.validationErrors;
// Get all successful results
List<FormValidationResult> successes = bag.validationSuccess;
}
FormValidationResult
प्रत्येक FormValidationResult एक सिंगल वैल्यू के वैलिडेशन का परिणाम दर्शाता है:
FormValidator validator = FormValidator(data: "test@email.com")
.email()
.maxLength(50);
FormValidationResult result = validator.check();
if (result.isValid) {
print("Valid!");
} else {
// First error message
String? message = result.getFirstErrorMessage();
// All error messages
List<String> messages = result.errorMessages();
// Error responses
List<FormValidationError> errors = result.errorResponses;
}
FormValidator का उपयोग
FormValidator का उपयोग स्टैंडअलोन या फ़ॉर्म फ़ील्ड्स के साथ किया जा सकता है।
स्टैंडअलोन उपयोग
// Using a named constructor
FormValidator validator = FormValidator.email();
FormValidationResult result = validator.check("user@example.com");
if (result.isValid) {
print("Email is valid");
} else {
String? errorMessage = result.getFirstErrorMessage();
print("Error: $errorMessage");
}
कंस्ट्रक्टर में डेटा के साथ
FormValidator validator = FormValidator(data: "user@example.com", attribute: "Email")
.email()
.maxLength(50);
FormValidationResult result = validator.check();
print(result.isValid); // true
FormValidator नेम्ड कंस्ट्रक्टर्स
Nylo Website v7 सामान्य वैलिडेशन के लिए नेम्ड कंस्ट्रक्टर्स प्रदान करता है:
// Email validation
FormValidator.email(message: "Please enter a valid email")
// Password validation (strength 1 or 2)
FormValidator.password(strength: 1)
FormValidator.password(strength: 2, message: "Password too weak")
// Phone numbers
FormValidator.phoneNumberUk()
FormValidator.phoneNumberUs()
// URL validation
FormValidator.url()
// Length constraints
FormValidator.minLength(5, message: "Too short")
FormValidator.maxLength(100, message: "Too long")
// Value constraints
FormValidator.minValue(18, message: "Must be 18+")
FormValidator.maxValue(100)
// Size constraints (for lists/strings)
FormValidator.minSize(2, message: "Select at least 2")
FormValidator.maxSize(5)
// Not empty
FormValidator.notEmpty(message: "This field is required")
// Contains values
FormValidator.contains(['option1', 'option2'])
// Starts/ends with
FormValidator.beginsWith("https://")
FormValidator.endsWith(".com")
// Boolean checks
FormValidator.booleanTrue(message: "Must accept terms")
FormValidator.booleanFalse()
// Numeric
FormValidator.numeric()
// Date validations
FormValidator.date()
FormValidator.dateInPast()
FormValidator.dateInFuture()
FormValidator.dateAgeIsOlder(18, message: "Must be 18+")
FormValidator.dateAgeIsYounger(65)
// Text case
FormValidator.uppercase()
FormValidator.lowercase()
FormValidator.capitalized()
// Location formats
FormValidator.zipcodeUs()
FormValidator.postcodeUk()
// Regex pattern
FormValidator.regex(r'^[A-Z]{3}\d{4}$', message: "Invalid format")
// Custom validation
FormValidator.custom(
message: "Invalid value",
validate: (data) => data != null,
)
वैलिडेशन नियम चेन करना
इंस्टेंस मेथड्स का उपयोग करके कई नियमों को धाराप्रवाह रूप से चेन करें। प्रत्येक मेथड FormValidator रिटर्न करता है, जिससे आप नियम बना सकते हैं:
FormValidator validator = FormValidator()
.notEmpty()
.email()
.maxLength(50);
FormValidationResult result = validator.check("user@example.com");
if (!result.isValid) {
List<String> errors = result.errorMessages();
print(errors);
}
सभी नेम्ड कंस्ट्रक्टर्स के संबंधित चेन करने योग्य इंस्टेंस मेथड्स हैं:
FormValidator()
.notEmpty(message: "Required")
.email(message: "Invalid email")
.minLength(5, message: "Too short")
.maxLength(100, message: "Too long")
.beginsWith("user", message: "Must start with 'user'")
.lowercase(message: "Must be lowercase")
कस्टम वैलिडेशन
कस्टम नियम (इनलाइन)
इनलाइन वैलिडेशन लॉजिक जोड़ने के लिए .custom() का उपयोग करें:
FormValidator.custom(
message: "Username already taken",
validate: (data) {
// Return true if valid, false if invalid
return !_takenUsernames.contains(data);
},
)
या इसे अन्य नियमों के साथ चेन करें:
FormValidator()
.notEmpty()
.custom(
message: "Must start with a letter",
validate: (data) => RegExp(r'^[a-zA-Z]').hasMatch(data.toString()),
)
इक्वल्स वैलिडेशन
जाँचें कि कोई वैल्यू दूसरी से मेल खाती है:
FormValidator()
.notEmpty()
.equals(
_passwordController.text,
message: "Passwords must match",
)
फ़ील्ड्स के साथ FormValidator का उपयोग
FormValidator फ़ॉर्म्स में Field विजेट्स के साथ इंटीग्रेट होता है। validator पैरामीटर में एक वैलिडेटर पास करें:
class RegisterForm extends NyFormData {
RegisterForm({String? name}) : super(name ?? "register");
@override
fields() => [
Field.text(
"Name",
autofocus: true,
validator: FormValidator.notEmpty(),
),
Field.email("Email", validator: FormValidator.email()),
Field.password(
"Password",
validator: FormValidator.password(strength: 1),
),
];
}
आप फ़ील्ड्स के साथ चेन किए गए वैलिडेटर्स का भी उपयोग कर सकते हैं:
Field.text(
"Username",
validator: FormValidator()
.notEmpty(message: "Username is required")
.minLength(3, message: "At least 3 characters")
.maxLength(20, message: "At most 20 characters"),
)
Field.slider(
"Rating",
validator: FormValidator.minValue(4, message: "Rating must be at least 4"),
)
उपलब्ध वैलिडेशन नियम
FormValidator के लिए सभी उपलब्ध नियम, नेम्ड कंस्ट्रक्टर्स और चेन करने योग्य मेथड्स दोनों के रूप में:
| नियम | नेम्ड कंस्ट्रक्टर | चेन करने योग्य मेथड | विवरण |
|---|---|---|---|
| ईमेल | FormValidator.email() |
.email() |
ईमेल फ़ॉर्मेट वैलिडेट करता है |
| पासवर्ड | FormValidator.password(strength: 1) |
.password(strength: 1) |
स्ट्रेंथ 1: 8+ कैरेक्टर, 1 अपरकेस, 1 अंक। स्ट्रेंथ 2: + 1 स्पेशल कैरेक्टर |
| खाली नहीं | FormValidator.notEmpty() |
.notEmpty() |
खाली नहीं हो सकता |
| न्यूनतम लंबाई | FormValidator.minLength(5) |
.minLength(5) |
न्यूनतम स्ट्रिंग लंबाई |
| अधिकतम लंबाई | FormValidator.maxLength(100) |
.maxLength(100) |
अधिकतम स्ट्रिंग लंबाई |
| न्यूनतम वैल्यू | FormValidator.minValue(18) |
.minValue(18) |
न्यूनतम संख्यात्मक वैल्यू (स्ट्रिंग लंबाई, सूची लंबाई, मैप लंबाई पर भी काम करता है) |
| अधिकतम वैल्यू | FormValidator.maxValue(100) |
.maxValue(100) |
अधिकतम संख्यात्मक वैल्यू |
| न्यूनतम साइज़ | FormValidator.minSize(2) |
.minSize(2) |
सूचियों/स्ट्रिंग्स के लिए न्यूनतम साइज़ |
| अधिकतम साइज़ | FormValidator.maxSize(5) |
.maxSize(5) |
सूचियों/स्ट्रिंग्स के लिए अधिकतम साइज़ |
| शामिल है | FormValidator.contains(['a', 'b']) |
.contains(['a', 'b']) |
वैल्यू में दी गई वैल्यूज़ में से एक होनी चाहिए |
| से शुरू होता है | FormValidator.beginsWith("https://") |
.beginsWith("https://") |
स्ट्रिंग प्रीफ़िक्स से शुरू होनी चाहिए |
| पर समाप्त होता है | FormValidator.endsWith(".com") |
.endsWith(".com") |
स्ट्रिंग सफ़िक्स पर समाप्त होनी चाहिए |
| URL | FormValidator.url() |
.url() |
URL फ़ॉर्मेट वैलिडेट करता है |
| संख्यात्मक | FormValidator.numeric() |
.numeric() |
एक संख्या होनी चाहिए |
| बूलियन True | FormValidator.booleanTrue() |
.booleanTrue() |
true होना चाहिए |
| बूलियन False | FormValidator.booleanFalse() |
.booleanFalse() |
false होना चाहिए |
| तिथि | FormValidator.date() |
.date() |
एक वैध तिथि होनी चाहिए |
| बीती तिथि | FormValidator.dateInPast() |
.dateInPast() |
तिथि अतीत में होनी चाहिए |
| भविष्य की तिथि | FormValidator.dateInFuture() |
.dateInFuture() |
तिथि भविष्य में होनी चाहिए |
| आयु बड़ी है | FormValidator.dateAgeIsOlder(18) |
.dateAgeIsOlder(18) |
आयु N से अधिक होनी चाहिए |
| आयु छोटी है | FormValidator.dateAgeIsYounger(65) |
.dateAgeIsYounger(65) |
आयु N से कम होनी चाहिए |
| कैपिटलाइज़्ड | FormValidator.capitalized() |
.capitalized() |
पहला अक्षर अपरकेस होना चाहिए |
| लोअरकेस | FormValidator.lowercase() |
.lowercase() |
सभी कैरेक्टर लोअरकेस होने चाहिए |
| अपरकेस | FormValidator.uppercase() |
.uppercase() |
सभी कैरेक्टर अपरकेस होने चाहिए |
| फ़ोन US | FormValidator.phoneNumberUs() |
.phoneNumberUs() |
US फ़ोन नंबर फ़ॉर्मेट |
| फ़ोन UK | FormValidator.phoneNumberUk() |
.phoneNumberUk() |
UK फ़ोन नंबर फ़ॉर्मेट |
| ज़िपकोड US | FormValidator.zipcodeUs() |
.zipcodeUs() |
US ज़िपकोड फ़ॉर्मेट |
| पोस्टकोड UK | FormValidator.postcodeUk() |
.postcodeUk() |
UK पोस्टकोड फ़ॉर्मेट |
| रीजेक्स | FormValidator.regex(r'pattern') |
.regex(r'pattern') |
रीजेक्स पैटर्न से मेल खाना चाहिए |
| इक्वल्स | — | .equals(otherValue) |
दूसरी वैल्यू के बराबर होना चाहिए |
| कस्टम | FormValidator.custom(validate: fn) |
.custom(validate: fn) |
कस्टम वैलिडेशन फ़ंक्शन |
सभी नियम एरर मैसेज कस्टमाइज़ करने के लिए एक वैकल्पिक message पैरामीटर स्वीकार करते हैं।
कस्टम वैलिडेशन नियम बनाना
पुन: प्रयोज्य वैलिडेशन नियम बनाने के लिए, FormRule क्लास को एक्सटेंड करें:
class FormRuleUsername extends FormRule {
@override
String? rule = "username";
@override
String? message = "The {{attribute}} must be a valid username.";
FormRuleUsername({String? message}) {
if (message != null) {
this.message = message;
}
}
@override
bool validate(data) {
if (data is! String) return false;
// Username: alphanumeric, underscores, 3-20 chars
return RegExp(r'^[a-zA-Z0-9_]{3,20}$').hasMatch(data);
}
}
message में प्लेसहोल्डर के रूप में {{attribute}} का उपयोग करें -- रनटाइम पर इसे फ़ील्ड के लेबल से बदल दिया जाएगा।
कस्टम FormRule का उपयोग
FormValidator.rule() का उपयोग करके अपना कस्टम नियम FormValidator में जोड़ें:
FormValidator validator = FormValidator.rule([
FormRuleNotEmpty(),
FormRuleUsername(),
]);
FormValidationResult result = validator.check("my_username");
या क्लास बनाए बिना एक-बार के नियमों के लिए .custom() मेथड का उपयोग करें:
FormValidator()
.notEmpty()
.custom(
message: "Username must start with a letter",
validate: (data) => RegExp(r'^[a-zA-Z]').hasMatch(data.toString()),
)