জাভাস্ক্রিপ্ট ফর্ম ভেলিডেশন (JavaScript Form Validation Tutorial in Bangla)

 




জাভাস্ক্রিপ্ট দিয়ে ফর্ম ভেলিডেশন করা যায়। টেক্সট ইনপুট, সিলেক্টবক্স, চেকবক্স ইত্যাদি যেকোন এইচটিএমএল ফর্ম এলিমেন্ট হোক না কেন, আপনি জাভাস্ক্রিপ্ট দিয়ে চেক করতে পারবেন ইউজার ফর্ম পূরন করেছে কিনা এবং সঠিক তথ্য দিয়েছে কিনা। যদি ফর্ম ঠিকমত পূরন না করে তাহলে ইউজার ফর্ম সাবমিট করতে পারবেনা এবং তাকে ফর্ম পূরনের নির্দেশনাও জাভাস্ক্রিপ্ট দিয়ে দিতে পারেন।

জাভাস্ক্রিপ্ট দিয়ে ফর্ম এলিমেন্ট একসেস করা কয়েকটি উপায় আছে যেমন

document.formName.elements[0] এভাবে ফর্মের প্রথম এলিমেন্ট টিকে একসেস করা যাবে। যদি সেই ফর্ম ফিল্ডে কোন মান থাকে এবং সেটা চান তাহলে

01.<!DOCTYPE html>
02.<html>
03.<head>
04.<script>
05. 
06.function validateForm(){
07.var t = document.wForm.elements[0].value;
08.alert(t);
09.}
10. 
11.</script>
12.</head>
13.<body>
14. 
15.<form action="" name="wForm" method="post" onsubmit="validateForm()">
16.<p><input type="text" name="first_name" id="first_name"/></p>
17.<p><input type="submit" name="submit" value="Submit"/></p>
18.</form>
19. 
20.</body>
21.</html>

test.html নামে সেভ করে রান করিয়ে দেখুন। ৭ নাম্বার লাইনে elements[0] দেয়াতে ফর্মের প্রথম এলিমেন্ট টি একসেস করেছে, ওখানে যত নাম্বার দিবেন সেই নম্বর এলিমেন্ট একসেস করবে।

এভঅবে নাম্বার না দিয়ে নাম দিয়েও একসেস করা যায় যেমন

1.document.wForm.elements['first_name'].value;


তবে এর চেয়ে আরেকটা ভাল পদ্ধতি আছে এটাই প্রফেশনালি করা হয় তা হচ্ছে getElementById() ফাংশন ব্যবহার করে। যেমন

1.var f_name = document.getElementById('first_name').value;


** getElementByI() এর ভিতরে কোটেশন দিয়ে যে এলিমেন্ট একসেস করবেন সেটার id এবং ডট (.) দিয়ে value প্রোপার্টিজ দিলেই ইনপুট এলিমেন্টটির মান পেয়ে যাবেন।


টেক্সট ফিল্ড ভেলিডেশন

আপনার ফর্মে টেক্সট ফিল্ড আছে আপনি চান সেটা পূরন না করে যেন ইউজার ফর্ম সাবমিট করতে না পারে।

01.<!DOCTYPE html>
02.<html>
03.<head>
04.<script>
05. 
06.function validateForm(){
07.var t = document.getElementById('first_name').value;
08.if(t.length == 0){
09.alert('Please enter any value');
10.return false;
11.}else if(isNaN(t) == false){
12.alert('Please enter any text');
13.return false;
14.}else{
15.alert('form submitted');
16.return true;
17.}
18.}
19. 
20.</script>
21.</head>
22.<body>
23. 
24.<form action="" name="wForm" method="post" onsubmit="return validateForm()">
25.<p><input type="text" name="first_name" id="first_name"/></p>
26.<p><input type="submit" name="submit" value="Submit"/></p>
27.</form>
28. 
29.</body>
30.</html>


** এই কোড দেখবে ইউজার ফর্ম পূরন করেছে কিনা এবং ফিল্ডে টেক্সট দিয়েছে কিনা।


** প্রথমে t ভেরিয়েবলে first_name ফিল্ডের মান নিয়েছি এরপর length একটা প্রোপার্টি আছে সেটা দিয়ে চেক করা যায় যে কতটি অক্ষর ই্নপুট বক্সে দিয়েছে। যদি t.length == 0 হয় অর্থ্যাৎ কোন কিছুই টাইপ করে নাই তখন একটা এলার্ট মেসেজ (কিছু টাইপ করতে হবে এমন একটা মেসেজ) দিয়ে রিটার্ন করে দিয়েছি।

কিছু টাইপ করে কিন্তু সেটা নাম্বার টাইপ করল তখন if স্টেটমেন্ট পাশ করবে এবং  else if দিয়ে চেক হবে টাইপকৃত লেখা নাম্বার কিনা। isNaN একটা ফাংশন এটা দিয়ে নাম্বার চেক করা যায় (নাম্বারটি শুদ্ধ কিনা)। যদি isNaN(t) == false হয় তাহলে তার মানে নাম্বার টাইপ করেছে তখন এলার্ট দিয়ে রিটার্ন করে দিয়েছি। কেননা মানুষের নামতো কখনও নাম্বার হবেনা। NaN (Not a Number).


** ২৪ নম্বর লাইনে return এরপর ফাংশনটি দিয়েছি কেননা ফাংশনটি true অথবা false রিটার্ন করবে। false রিটার্ন করলে ফর্ম সাবমিট হবেনা।


** টেক্সট চেক করতে isNaN এর পরিবর্তে রেগুলার এক্সপ্রেশনও ব্যবহার করতে পারেন। যেমন

01.function validateForm(){
02.var t = document.getElementById('first_name').value;  var regEx = /^[a-zA-Z]+$/;
03.if(t.length == 0){
04.alert('Please enter any value');
05.return false;
06.}else if(t.match(regEx) == null){
07.alert('Please enter any text');
08.return false;
09.}else{
10.alert('form submitted');
11.return true;
12.}
13.}

** t.match(regEx) null রিটার্ন করে যদি অক্ষর ব্যাতিত অন্য কিছু টাইপ করে। isNaN এ চেয়ে এই পদ্ধতি বেশি ভাল হবে।


ইমেইল এবং নাম্বার ফিল্ড ভেলিডেশন

01.<!DOCTYPE html>
02.<html>
03.<head>
04.<script>
05. 
06.function validateForm(){
07.var age = document.getElementById('age').value;
08.var email = document.getElementById('email').value;
09. 
10.var filter = /^[a-zA-Z0-9]+[a-zA-Z0-9_.-]+[a-zA-Z0-9_-]+@[a-zA-Z0-9]+[a-zA-Z0-9.-]+[a-zA-Z0-9]+.[a-z]{2,4}$/;
11. 
12.if(age.length == 0 || isNaN(age)){
13.alert('Please enter any number');
14.return false;
15.}else if(email.length == 0 || filter.test(email) != true){
16.alert('Please enter valid email');
17.return false;
18.}else{
19.alert('form submitted');
20.return true;
21.}
22.}
23. 
24.</script>
25.</head>
26.<body>
27. 
28.<form action="test.php" name="wForm" method="post" onsubmit="return validateForm()">
29.<p><input type="text" name="age" id="age"/></p>
30.<p><input type="text" name="email" id="email"/></p>
31.<p><input type="submit" name="submit" value="Submit"/></p>
32.</form>
33. 
34.</body>
35.</html>

test.html নামে সেভ করে রান করে দেখুন। একসাথে নাম্বার এবং ইমেইল ভেলিডেশন করেছি।

** প্রথমে age বা বয়স যদি না দেয় কিংবা কোন টেক্সট টাইপ করে (বয়স তো নাম্বার দিয়েই দিতে হয়) তখন এলার্ট দিয়ে false রিটার্ন করেছি। এরপর filter এ ইমেইল এর জন্য একটা রেগুলার এক্সপ্রেশন তৈরী করেছি এবং test() মেথড দিয়ে চেক করেছি সঠিক ইমেইল ঠিকানা টাইপ করেছে কিনা সাথে সাথে or (||) অপারেটর দিয়ে দেখেছি ইমেইল ফিল্ড ফাকা কিনা।


** ইমেইলের জন্য রেগুলার এক্সপ্রেশন নেটে সার্চ দিলে অনেক পাওয়া যায় তবে যদি নিজেই বানানো শিখতে চান তাহলে আমাদের একটা রেগুলার এক্সপ্রেশন টিউটোরিয়াল আছে পিএইচপিতে।

Post a Comment

Cookie Consent
Little Blog serve cookies on this site to analyze traffic, remember your preferences, and optimize your experience.
Oops!
It seems there is something wrong with your internet connection. Please connect to the data/wifi internet and start browsing again.
AdBlock Detected!
We have detected that you are using adblocking plugin in your browser.
The revenue we earn by the advertisements is used to manage this website, we request you to whitelist our website in your adblocking plugin.
Site is Blocked
Sorry! This site is not available in your country.