ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி C# இல் கிளையண்ட்-பக்கம் படிவம் சரிபார்ப்பு
சமர்ப்பிக்கப்படும் தரவு துல்லியமாகவும் முழுமையானதாகவும் இருப்பதை உறுதிசெய்ய, வலைப் பயன்பாடுகளை உருவாக்கும் போது படிவ சரிபார்ப்பு ஒரு முக்கியமான படியாகும். டெவலப்பர்கள் பெரும்பாலும் சர்வர் பக்க அல்லது கிளையன்ட் பக்க சரிபார்ப்பு முறைகளை தேர்வு செய்கிறார்கள். C# இல் உள்ள ஒரு பொதுவான அணுகுமுறையானது, சர்வர் பக்க சரிபார்ப்புக்கு தரவுகுறிப்புகளைப் பயன்படுத்துவதாகும். இருப்பினும், இது எப்போதும் எல்லா சூழ்நிலையிலும் பொருந்தாது.
சில சந்தர்ப்பங்களில், ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி கிளையன்ட் பக்க சரிபார்ப்பு மிகவும் ஆற்றல்மிக்க பயனர் அனுபவத்தை வழங்க முடியும், இது சேவையகத்திற்கு அனுப்பப்படுவதற்கு முன்பு பிழைகளை பிடிக்க அனுமதிக்கிறது. இந்த அணுகுமுறை தேவையற்ற சர்வர் கோரிக்கைகளைத் தடுக்கிறது, செயல்திறன் மற்றும் பயனர் தொடர்பு இரண்டையும் மேம்படுத்துகிறது.
இந்தக் கட்டுரையில், நிலையான தரவுக் குறிப்புகள் பண்புக்கூறுகளை நம்பாமல், ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி C# இல் ஒரு படிவத்தை எவ்வாறு சரிபார்க்கலாம் என்பதை ஆராய்வோம். குறிப்பாக, பல உரைப் பகுதிகளைச் சரிபார்ப்பதிலும், சமர்ப்பித்தவுடன் படிவம் முன்கூட்டியே மீண்டும் ஏற்றப்படாமல் இருப்பதை உறுதி செய்வதிலும் கவனம் செலுத்துவோம்.
உங்கள் படிவத்தில் ஏற்கனவே தரவு இருந்தால் மற்றும் புலங்களில் ஒன்றை நீங்கள் அழித்திருந்தால், எதிர்பார்க்கப்படும் விழிப்பூட்டல்களைக் காட்டாமல் படிவம் மீண்டும் ஏற்றப்படும்போது சிக்கல்களைச் சந்திக்க நேரிடும். இது ஏன் நிகழ்கிறது மற்றும் திறமையான ஜாவாஸ்கிரிப்ட் லாஜிக்கைப் பயன்படுத்தி அதை எவ்வாறு தீர்ப்பது என்பதை நாங்கள் முழுக்குவோம்.
கட்டளை | பயன்பாட்டின் உதாரணம் |
---|---|
event.preventDefault() | இயல்புநிலை படிவ சமர்ப்பிப்பு நடத்தையைத் தடுக்க இந்த கட்டளை பயன்படுத்தப்படுகிறது. இந்த நிலையில், பக்கத்தை மறுஏற்றம் செய்வதிலிருந்து படிவத்தை நிறுத்துகிறது, ஜாவாஸ்கிரிப்ட் சரிபார்ப்பு தர்க்கத்தை விரும்பியபடி செயல்பட அனுமதிக்கிறது. |
document.getElementById() | படிவ உறுப்பை அதன் ஐடி மூலம் தேர்ந்தெடுக்கப் பயன்படுகிறது. DOM (ஆவண பொருள் மாதிரி) இல் சரியான படிவத்தில் சரிபார்ப்பு தர்க்கத்தை இலக்காகக் கொண்டு பயன்படுத்துவதற்கு இது அவசியம். |
querySelectorAll() | படிவத்தில் உள்ள அனைத்து உரை பகுதி கூறுகளையும் தேர்ந்தெடுக்க இந்த கட்டளை பயன்படுத்தப்படுகிறது. இது அனைத்து உரை பகுதிகளின் நோட்லிஸ்ட்டை வழங்குகிறது, சரிபார்ப்பிற்காக பல உறுப்புகளில் மீண்டும் மீண்டும் செய்ய உதவுகிறது. |
classList.add() | ஒரு உறுப்புக்கு CSS வகுப்பைச் சேர்க்கிறது. சரிபார்ப்பில் தோல்வியுற்ற உரை பகுதிகளுக்கு "தவறான" வகுப்பைச் சேர்ப்பதற்கு இது மிகவும் பயனுள்ளதாக இருக்கும், இது பயனருக்குப் பிழையைக் காட்டுகிறது. |
classList.remove() | ஒரு உறுப்பிலிருந்து CSS வகுப்பை நீக்குகிறது. இந்த வழக்கில், "தவறான" வகுப்பை உரை பகுதிகள் சரியாக நிரப்பியவுடன் அகற்றி, முந்தைய பிழை நிலையை அழிக்கும். |
ModelState.AddModelError() | இந்த C# கட்டளை ASP.NET Core இல் சர்வர் பக்கத்தில் சரிபார்ப்பு சோதனை தோல்வியடையும் போது, மாதிரி நிலைக்கு ஒரு பிழை செய்தியை சேர்க்க பயன்படுத்தப்படுகிறது. படிவத்தைச் சமர்ப்பித்த பிறகு சரிபார்ப்பு தோல்விகளைப் பற்றி பயனர்களுக்குத் தெரிவிப்பது முக்கியம். |
ModelState.ContainsKey() | மாதிரி நிலையில் ஒரு குறிப்பிட்ட விசை (பிழை செய்தி) உள்ளதா என்பதை இந்த கட்டளை சரிபார்க்கிறது. சர்வர்-பக்கம் சரிபார்த்தல் பிழையை சரியாகப் பிடித்திருந்தால் சரிபார்ப்பதற்கு இது அவசியம். |
Assert.Equal() | அலகு சோதனையில் பயன்படுத்தப்படுகிறது, இந்த கட்டளை இரண்டு மதிப்புகள் சமமாக இருந்தால் சரிபார்க்கிறது. இந்த எடுத்துக்காட்டில், படிவ சரிபார்ப்பு தோல்வியுற்றால், சர்வர் பதிலில் எதிர்பார்க்கப்படும் பிழை செய்தி தோன்றுகிறதா என்பதை இது சரிபார்க்கிறது. |
RedirectToAction() | படிவ சரிபார்ப்பு வெற்றிகரமாக இருந்தால், இந்த கட்டளை பயனரை வேறு கட்டுப்பாட்டு நடவடிக்கைக்கு திருப்பிவிடும். சரிபார்ப்பு தோல்வியுற்றால் படிவத்தை மேலும் செயலாக்குவதை இது தடுக்கிறது. |
ஜாவாஸ்கிரிப்ட் மற்றும் சி# மூலம் கிளையன்ட்-சைட் ஃபார்ம் சரிபார்ப்பைப் புரிந்துகொள்வது
இந்தக் கட்டுரையில், C# ASP.NET கோர் திட்டத்திற்காக ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி எளிமையான படிவ சரிபார்ப்பு பொறிமுறையை உருவாக்குவதில் கவனம் செலுத்துகிறோம். படிவத்தில் பல உரைப் பகுதிகள் உள்ளன, அங்கு பயனர் தகவல்களை உள்ளிடுவார் என்று எதிர்பார்க்கப்படுகிறது, மேலும் படிவம் சமர்ப்பிக்கப்படுவதற்கு முன்பு அனைத்து புலங்களும் சரியாக நிரப்பப்படுவதை உறுதிசெய்ய JavaScript ஐப் பயன்படுத்துகிறோம். C# DataAnnotations ஐத் தவிர்ப்பதன் மூலம், தேவையில்லாமல் பக்கம் மீண்டும் ஏற்றப்படுவதைத் தடுக்கும் வகையில், உடனடியாக ஏற்படும் தனிப்பயன் முன்-இறுதிச் சரிபார்ப்பை நாங்கள் செயல்படுத்துகிறோம். இந்த முறை தேவையற்ற சர்வர் அழைப்புகளை குறைப்பதன் மூலம் செயல்திறன் மற்றும் பயனர் அனுபவத்தை மேம்படுத்துகிறது.
இதை நிறைவேற்ற, தி JavaScript செயல்பாடு படிவத்தில் உள்ள அனைத்து உரை பகுதிகளையும் சரிபார்க்கிறது. கட்டளை அனைத்து textarea கூறுகளையும் சேகரிக்கப் பயன்படுகிறது, பின்னர் அவை ஒரு சுழற்சியைப் பயன்படுத்தி மீண்டும் மீண்டும் செய்யப்படுகின்றன. ஏதேனும் உரைப் பகுதி காலியாகக் காணப்பட்டால் (அதாவது, மதிப்பு இடைவெளிகள் அல்லது முற்றிலும் காலியாக இருந்தால்), தி கொடி பொய்யாக அமைக்கப்பட்டுள்ளது. இது நிகழும்போது, செயல்பாடு அனைத்து புலங்களும் நிரப்பப்பட வேண்டும் என்று பயனருக்கு அறிவிக்கும் எச்சரிக்கையைத் தூண்டுகிறது, மேலும் படிவச் சமர்ப்பிப்பு இதைப் பயன்படுத்தி நிறுத்தப்படும் Event.preventDefault(). இது பக்கத்தை மறுஏற்றம் செய்வதிலிருந்து திறம்பட தடுக்கிறது, பயனர் தவறை சரிசெய்ய அனுமதிக்கிறது.
ஒரு பயனர் உரைப் பகுதியிலிருந்து தரவை அழித்து, படிவத்தைச் சமர்ப்பிக்கும் போது விவரிக்கப்பட்ட சிக்கல் எழுகிறது. படிவம் முன்பே நிரப்பப்பட்டு, புலம் அழிக்கப்படும் சந்தர்ப்பங்களில், எங்கள் சரிபார்ப்பு சரியாக வேலை செய்யவில்லை என்றால், பக்கம் விழிப்பூட்டலைக் காட்டாமல் மீண்டும் ஏற்றப்படும். எப்போது இந்தப் பிரச்சினை ஏற்படுகிறது சரியாக அழைக்கப்படவில்லை, சரிபார்ப்பு தர்க்கம் அழிக்கப்பட்ட புலத்தை தவறானது என கண்டறியாததன் காரணமாக இருக்கலாம். ஜாவாஸ்கிரிப்ட் சரிபார்ப்பு காலியான புலங்களை மாறும் வகையில் சரிபார்க்கிறது என்பதை உறுதி செய்வதன் மூலம், இந்தச் சிக்கலைத் தவிர்க்கலாம். கூடுதலாக, சரிபார்ப்பு தர்க்கம், காசோலை முடிவதற்குள் படிவத்தை மறுஏற்றம் செய்யக்கூடிய சாத்தியமான ஒத்திசைவற்ற சிக்கல்களைத் தீர்க்க வேண்டும்.
கடைசியாக, சர்வர் பக்க சரிபார்ப்பு, C# இல் செயல்படுத்தப்பட்டது , கிளையன்ட் பக்க சரிபார்ப்பு தோல்வியுற்றால் அல்லது புறக்கணிக்கப்படும் போது ஒரு பின்னடைவாக செயல்படுகிறது. ஜாவாஸ்கிரிப்ட் பெரும்பாலான சரிபார்ப்புப் பணிகளைக் கையாளுகிறது என்றாலும், சர்வர் பக்க சரிபார்ப்பு முழுமையடையாத அல்லது தவறான தரவு சேவையகத்தில் சமர்ப்பிக்கப்படாமல் இருப்பதை உறுதி செய்கிறது. இந்த இரட்டை அடுக்கு அணுகுமுறை, முன்-இறுதி மற்றும் பின்-இறுதி சரிபார்ப்பு இரண்டையும் பயன்படுத்தி, உகந்த படிவ சரிபார்ப்பு பாதுகாப்பு மற்றும் செயல்திறனை உறுதி செய்கிறது. இந்த அமைப்பின் மூலம், படிவத்தை பயனருக்கு ஏற்றதாகவும் வேகமாகவும் வைத்திருக்கும் போது, சரியான தரவு மட்டுமே செயலாக்கப்படும் என்பதில் உறுதியாக இருக்க முடியும்.
தரவு குறிப்புகள் இல்லாமல் C# இல் கிளையண்ட் பக்க சரிபார்ப்பு
இந்த தீர்வு C# ASP.NET கோர் சூழலில் படிவத்தை சமர்ப்பிப்பதற்கு முன் முன்-இறுதி சரிபார்ப்புக்கு JavaScript ஐப் பயன்படுத்துகிறது. உரைப் பகுதிகள் நிரப்பப்பட்டுள்ளனவா என்பதைச் சரிபார்ப்பதன் மூலம் இது படிவச் சரிபார்ப்பை வழங்குகிறது.
function validateForm(event) {
const form = document.getElementById('MyForm');
let textAreas = form.querySelectorAll('textarea');
let allFilled = true;
for (let i = 0; i < textAreas.length; i++) {
if (textAreas[i].value.trim() === "") {
allFilled = false;
break;
}
}
if (!allFilled) {
alert("All fields are required.");
event.preventDefault();
return false;
}
return true;
}
ASP.NET கோர் பயன்படுத்தி C# இல் சர்வர்-சைட் சரிபார்ப்பு
புலங்கள் காலியாக விடப்படாமல் இருப்பதை உறுதிசெய்ய ASP.NET கோர் மாடல் பைண்டிங் சிஸ்டத்தைப் பயன்படுத்தி C# இல் பின்தள சரிபார்ப்பைப் பயன்படுத்துவதில் இந்த அணுகுமுறை கவனம் செலுத்துகிறது. படிவ சமர்ப்பிப்பு சர்வரில் சரிபார்க்கப்பட்டது.
[HttpPost]
public IActionResult SaveForm(ModelExample model)
{
if (string.IsNullOrEmpty(model.Name) ||
string.IsNullOrEmpty(model.Name2) ||
string.IsNullOrEmpty(model.Name3))
{
ModelState.AddModelError("", "All fields must be filled.");
return View(model);
}
// Continue processing
return RedirectToAction("Success");
}
தனிப்பயன் பிழை செய்திகளுடன் மேம்படுத்தப்பட்ட ஜாவாஸ்கிரிப்ட் சரிபார்ப்பு
இந்த அணுகுமுறை கிளையன்ட் பக்க சரிபார்ப்பில் விரிவடைகிறது, ஒவ்வொரு குறிப்பிட்ட புலத்திற்கும் விரிவான பிழை செய்திகளை வழங்குவதன் மூலம் படிவ சரிபார்ப்பை மிகவும் பயனர் நட்புடன் மாற்றுகிறது.
function validateForm(event) {
const form = document.getElementById('MyForm');
let textAreas = form.querySelectorAll('textarea');
let allValid = true;
for (let i = 0; i < textAreas.length; i++) {
if (textAreas[i].value.trim() === "") {
textAreas[i].classList.add('is-invalid');
allValid = false;
} else {
textAreas[i].classList.remove('is-invalid');
}
}
if (!allValid) {
event.preventDefault();
alert("Please fill in all required fields.");
return false;
}
return true;
}
பின்நிலை படிவ சரிபார்ப்புக்கான அலகு சோதனை
இந்த யூனிட் சோதனையானது, வெற்றுப் புலங்கள் பதிலில் மாதிரிப் பிழையை அளிக்கின்றனவா என்பதைச் சரிபார்ப்பதன் மூலம், பின்தளப் படிவச் சரிபார்ப்பு சரியாகச் செயல்படுகிறதா என்பதைச் சரிபார்க்கிறது.
[Fact]
public void TestFormValidation() {
var controller = new MyController();
var model = new ModelExample { Name = "", Name2 = "Valid", Name3 = "" };
var result = controller.SaveForm(model);
Assert.True(controller.ModelState.ContainsKey(""));
Assert.Equal("All fields must be filled.",
controller.ModelState[""].Errors[0].ErrorMessage);
}
ஒத்திசைவற்ற ஜாவாஸ்கிரிப்ட் படிவ சரிபார்ப்பு நுட்பங்களை ஆய்வு செய்தல்
நாங்கள் கவனிக்காத ஒரு அம்சம் படிவக் கையாளுதலில் ஒத்திசைவற்ற சரிபார்ப்பின் பங்கு. ஒத்திசைவற்ற சரிபார்ப்பு டெவலப்பர்களை பயனர் அனுபவத்தைத் தடுக்காமல் படிவப் புலங்களைச் சரிபார்க்க அனுமதிக்கிறது. எடுத்துக்காட்டாக, பயனர்பெயரின் தனித்துவத்தை நீங்கள் சரிபார்க்கலாம் அல்லது நிகழ்நேரத்தில் மின்னஞ்சல் உள்ளதா என்பதைச் சரிபார்க்கலாம். இந்த முறையை ஜாவாஸ்கிரிப்ட் பயன்படுத்தி செயல்படுத்தலாம் அல்லது . இரண்டு முறைகளும் உடனடி கருத்துக்களை வழங்குவதன் மூலம் பயனர் அனுபவத்தை மேம்படுத்த உதவுகின்றன.
படிவ சரிபார்ப்பின் சூழலில், ஒத்திசைவற்ற கோரிக்கைகள், சர்வர் பதில்களுக்காகக் காத்திருக்கும் போது, பக்கத்தை ஊடாடுவதற்கு அனுமதிக்கின்றன. பெரிய தரவுத்தொகுப்புகள் அல்லது பல சரிபார்ப்பு விதிகளுடன் பணிபுரியும் போது இது உதவியாக இருக்கும், அதாவது ஒரு புலத்தில் உள்ளிடப்பட்ட உரை மற்ற புலங்களைத் தொடர்ந்து சரிபார்க்கும் போது ஒரு குறிப்பிட்ட வடிவமைப்பிற்கு இணங்குகிறதா எனச் சரிபார்ப்பது போன்றது. முன்-இறுதி மற்றும் ஒத்திசைவற்ற சரிபார்ப்பை இணைத்து, டெவலப்பர்கள் பக்கம் ஏற்றும் நேரத்தை மேம்படுத்தும் போது படிவ சரிபார்ப்பின் வலிமையை மேம்படுத்தலாம். சேவையகத்தை ஓவர்லோட் செய்வதைத் தவிர்க்க தேவையான போது மட்டுமே ஒத்திசைவற்ற கோரிக்கையைத் தூண்டுவது இங்கே முக்கியமானது.
ஒரு C# சூழலில் ஒத்திசைவற்ற சரிபார்ப்பைப் பயன்படுத்தும் போது, சர்வர் பக்க சரிபார்ப்பு ஒரு பின்னடைவாக செயல்படுவதையும் உறுதிசெய்ய வேண்டும். ஜாவாஸ்கிரிப்டை முடக்குவதன் மூலம் கிளையன்ட் பக்க சரிபார்ப்பை தவிர்க்க முடியும் என்பதால், சர்வர் பக்கத்தில் உள்ள உள்ளீடுகளை எப்போதும் சரிபார்க்கவும். இது தவறான தரவு எதுவும் நழுவாமல் இருப்பதை உறுதி செய்கிறது. பாரம்பரிய ஜாவாஸ்கிரிப்ட் உடன் ஒத்திசைவற்ற சரிபார்ப்பை மேம்படுத்துவது பாதுகாப்பான மற்றும் பயனர் நட்பு அனுபவத்தை அடைய உதவும், குறிப்பாக சரியான பிழை கையாளுதல் மற்றும் செயல்திறன் தேர்வுமுறை நுட்பங்களுடன் இணைந்தால்.
- பங்கு என்ன படிவ சரிபார்ப்பில்?
- சரிபார்ப்பு தோல்வியுற்றால், படிவத்தை சமர்ப்பிப்பதையும் பக்கத்தை மீண்டும் ஏற்றுவதையும் நிறுத்துகிறது. பயனர் படிவத்தை சரிசெய்வதற்கு பக்கம் தற்போதைய நிலையில் இருப்பதை இது உறுதி செய்கிறது.
- ஜாவாஸ்கிரிப்ட்டில் பல கூறுகளை எவ்வாறு தேர்ந்தெடுப்பது?
- நீங்கள் பயன்படுத்தலாம் உரைப் பகுதிகள் அல்லது உள்ளீட்டு புலங்கள் போன்ற பல கூறுகளைத் தேர்ந்தெடுக்கும் முறை. பொருந்தக்கூடிய கூறுகளின் பட்டியலை இது வழங்குகிறது, அதை நீங்கள் மீண்டும் மீண்டும் செய்யலாம்.
- ஒரு படிவத்தில் காலியான புலங்களைச் சரிபார்க்க சிறந்த வழி எது?
- காலியான புலங்களைச் சரிபார்க்க, பயன்படுத்தவும் . இந்த முறை வெற்று சரங்கள் மற்றும் வெறும் இடைவெளிகளைக் கொண்ட சரங்கள் இரண்டும் காலியாக இருப்பதை உறுதி செய்கிறது.
- ஒத்திசைவற்ற சரிபார்ப்பின் நன்மை என்ன?
- படிவத்தைச் சமர்ப்பிக்காமல் மின்னஞ்சல் முகவரிகள் அல்லது பயனர்பெயர்களைச் சரிபார்த்தல், உடனடி கருத்துக்களை வழங்குவதன் மூலம் பயனர் அனுபவத்தை மேம்படுத்துதல் போன்ற நிகழ்நேரச் சரிபார்ப்புகளை ஒத்திசைவற்ற சரிபார்ப்பு அனுமதிக்கிறது.
- JavaScript சரிபார்ப்பைப் பயன்படுத்தும் போது சர்வர் பக்க சரிபார்ப்பை தவிர்க்க முடியுமா?
- இல்லை, சர்வர் பக்க சரிபார்ப்பை தவிர்க்கக்கூடாது. ஜாவாஸ்கிரிப்ட் சரிபார்ப்புடன் கூட, சாத்தியமான பைபாஸ்கள் அல்லது தீங்கிழைக்கும் தரவு சமர்ப்பிப்புகளைத் தடுக்க, சர்வரில் தரவைச் சரிபார்ப்பது முக்கியம்.
முடிவில், C# பயன்பாடுகளில் ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி கிளையன்ட் பக்க சரிபார்ப்பைச் செயல்படுத்துவது பொதுவான சமர்ப்பிப்பு பிழைகளைத் தடுக்கலாம் மற்றும் பயனர் அனுபவத்தை மேம்படுத்தலாம். அனைத்து உரைப் பகுதிகளும் நிரப்பப்பட்டுள்ளதா எனச் சரிபார்த்து, படிவ நடத்தையை சரியாகக் கையாள்வதன் மூலம், சேவையகத்தை அடைவதற்கு முன், தரவுத் துல்லியத்தை உறுதிசெய்யலாம்.
மேலும், இதை சர்வர் பக்க சரிபார்ப்புடன் இணைப்பது வலுவான தரவு கையாளுதலை உறுதி செய்கிறது, ஏனெனில் கிளையன்ட் பக்க ஸ்கிரிப்ட்கள் புறக்கணிக்கப்படலாம். இந்த இரட்டை அணுகுமுறை செயல்திறன் மேம்பாடுகள் மற்றும் பாதுகாப்பு ஆகிய இரண்டையும் வழங்குகிறது, சரிபார்ப்பு சவால்களை உருவாக்குவதற்கான முழுமையான தீர்வை வழங்குகிறது.
- ASP.NET கோர் பயன்பாடுகளில் படிவ சரிபார்ப்புக்கு JavaScript ஐப் பயன்படுத்துவதை விரிவாகக் கூறுகிறது, வாடிக்கையாளர் பக்க சரிபார்ப்புக்கான சிறந்த நடைமுறைகளில் கவனம் செலுத்துகிறது. பற்றிய ஆவணங்களை உள்ளடக்கியது Microsoft ASP.NET கோர் சரிபார்ப்பு ஒரு குறிப்பு.
- என்பதை விளக்குகிறது Event.preventDefault() Mozilla Developer Network (MDN) ஆவணத்தில் இருந்து செயல்பாடு, சரிபார்ப்பு தோல்விகளின் போது படிவத்தை சமர்ப்பிப்பதை நிறுத்துவதற்கு இது அவசியம்.
- பயன்படுத்துவது பற்றிய விவரங்கள் querySelectorAll() W3Schools வழங்கிய சரிபார்ப்புக்கான பல படிவ கூறுகளை குறிவைக்க.