Friday, 27 April 2018

018 AngularJS Forms Validation

AngularJS Forms Validation

AngularJS support client end validation,  means you can  validate an input data in the client Browser before accepting.

          Beside validating ,
AngularJS offer validate status of form and input controls. AngularJS  monitor each activity of client , set the status of the control and form accordingly. 

The form has three mostly used status. 
  • $dirty - Inform that value has been changed.
  • $invalid - Inform that invalid value entered.
  • $error - states the exact error.

The control has several status as  below.




  • $untouched - The control has not been touched yet
  • $touched - The control has been touched
  • $pristine - The control has not been modified yet
  • $dirty - The control has been modified
  • $invalid - The control content is not valid
  • $valid - The control content is valid

HTMl5  attribute "required" , means that field must be  filled by the client.You have to add this attribute the control , that you want to validate.


 

Below is the example of control (field & email) validation 

Example


<html>
<head>
<title>AngularJS Example of Control Validation </title>
                <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js">
</script>
</head>

<script>
           var App = angular.module("myApp", []);

          App.controller('myController', function ($scope) 
     {
         });
</script>  

<body ng-app="myApp" ng-controller="myController">
<h1>
          AngularJS Required Field Validation</h1>
<form name="myForm">
<table border="0">
            <tr>
           <td>
                 Enter Name:
           </td>
          <td>
                      <input name="name" type="text" ng-model="myName" required>
                      <span style="color: red" ng-show="myForm.name.$dirty && myForm.name.$invalid">
                      <span ng-show="myForm.name.$error.required">First Name is required.</span>
               </span>
         </td>
        </tr>
        <tr>
       <td>
               Email:
       </td>
       <td>
                  <input name="email" type="email" ng-model="email" length="100" required>
                  <span style="color: red" ng-show="myForm.email.$dirty && myForm.email.$invalid">
                  <span ng-show="myForm.email.$error.required">Email is required.</span> <span
                  ng-show="myForm.email.$error.email">Invalid email address.</span> </span>
      </td>
</tr>
</table>
</form>
</body>
</html>


Output








 




Below is the example of Form validation with control(field & email) validation 



<html>
<head>
<title>AngularJS Example of Control & Form Validation </title>
                   <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js">
</script>
</head>

<script>
               var App = angular.module("myApp", []);

              App.controller('myController', function ($scope) 
        {
                });
</script>
 
<body ng-app="myApp" ng-controller="myController">
<h1>
AngularJS Required Field Validation</h1>
<form name="myForm">
         <table border="0">
         <tr>
        <td>
              Enter Name:
       </td>
       <td>
                 <input name="name" type="text" ng-model="myName" required>
                <span style="color: red" ng-show="myForm.name.$dirty && myForm.name.$invalid">
                <span ng-show="myForm.name.$error.required">First Name is required.</span>
       </span>
      </td>
       </tr>
      <tr>
      <td>
             Email:
       </td>
      <td>

           <input name="email" type="email" ng-model="email" length="100" required>
           <span style="color: red" ng-show="myForm.email.$dirty && myForm.email.$invalid">
          <span ng-show="myForm.email.$error.required">Email is required.</span> <span
           ng-show="myForm.email.$error.email">Invalid email address.</span> </span>
        </td>
     </tr>
<tr>
<td colspan="2">
               <button ng-disabled="myForm.myName.$dirty &&
                          myForm.myName.$invalid" >Submit</button>
</td>
</tr>
</table>
</form>
</body>
</html>

Output :








Custom validation
AngularJS offer validation to be Customized as per user. Below is example of custom validation.


Example

<html>
<head>
<title>AngularJS Example Custom Validation </title>
            <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js">
            </script>
</head>

<script>
          var app = angular.module("myApp", []);

          app.directive('regnumber', function () 
      {
           return 
            {
                       require: 'ngModel',
                       link: function (scope, element, attributes, control)  
                {
                                 control.$validators.adult = function (modelValue, viewValue)
                                  {
                                     var ln = viewValue.length;

                                    if (ln==4)
                                   {
                                             return true;
                                  
 
                                   return false; // wrong value
                     };
              }
     };
});

</script>
<div ng-app="myApp">
<form novalidate name="myForm">
              Your age: <input type="number" name="txtAge" ng-model="myRegNumber" regnumber />
              <span style="color:red;" ng-show="myForm.txtAge.$error.adult">Enter 4 digit  Registration Number only.</span>
</form>
</div>

Output :






CSS Classes
You can add CSS classes to forms and control with their states.
Below example show , how we can add css with states.


Example

<html>
<head>
          <title>AngularJS CSS Classes & States</title>
             <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js">
            </script>
</head>
<script>

         var App = angular.module("myApp", []);
         App.controller('myController', function ($scope) 
     {

         });
</script>

<style>
input.ng-invalid {
background-color :#F18D00;
}
input.ng-valid {
background-color:#93CCD7;
}
</style>


<body ng-app="myApp" ng-controller="myController">
<h1> AngularJS Required Field Validation</h1>

<form name="myForm">
          <table border="0">
          <tr>
          <td>
          Enter Name:
          </td>
          <td>
         <input name="name" type="text" ng-model="myName" required>
         <span style="color: red" ng-show="myForm.name.$dirty && myForm.name.$invalid"><span
        ng-show="myForm.name.$error.required">First Name is required.</span> </span>
        </td>
       </tr>
       <tr>
       <td>
        Email:
       </td>
      <td>
       <input name="email" type="email" ng-model="email" length="100" required>
       <span style="color: red" ng-show="myForm.email.$dirty && myForm.email.$invalid"><span
       ng-show="myForm.email.$error.required">Email is required.</span> <span ng-   show="myForm.email.$error.email">
         Invalid email address.</span> </span>
      </td>
     </tr>
</table>
</form>
</body>
</html>


Output :






বাঙালির বেড়ানো সেরা চারটি ঠিকানা

  বাঙালি মানে ঘোড়া পাগল | দু একদিন ছুটি পেলো মানে বাঙালি চলল ঘুরতে | সে সমুদ্রই হোক , পাহাড়ি হোক বা নদী হোক। বাঙালির ...