AngularJS下拉列表需要验证

AngularJS Dropdown required validation

本文关键字:验证 下拉列表 AngularJS      更新时间:2023-09-26

下面是我的代码片段。我想用angular来验证下拉列表。

<td align="left" width="52%"> 
  <span class="requiredSmall">*</span> 
    <select class="Sitedropdown" style="width: 220px;" 
            ng-model="selectedSpecimen().serviceID" 
            ng-options="service.ServiceID as service.ServiceName for service in services"> 
         <option value="" ng-selected="selected">Select Service</option> 
   </select> 
</td>

有效含义:

有效值可以是除了"Select Service"以外的任何值,这是我的默认值。像其他ASP.net要求字段验证器DefaultValue="0"的下拉菜单,所以这里我的下拉菜单将从服务绑定,我想选择所有其他的值,除了" select Service"

你需要添加一个name属性到你的下拉列表,然后你需要添加一个required属性,然后你可以使用myForm.[input name].$error.required引用错误:

HTML:

        <form name="myForm" ng-controller="Ctrl" ng-submit="save(myForm)" novalidate>
        <input type="text" name="txtServiceName" ng-model="ServiceName" required>
<span ng-show="myForm.txtServiceName.$error.required">Enter Service Name</span>
<br/>
          <select name="service_id" class="Sitedropdown" style="width: 220px;"          
                  ng-model="ServiceID" 
                  ng-options="service.ServiceID as service.ServiceName for service in services"
                  required> 
            <option value="">Select Service</option> 
          </select> 
          <span ng-show="myForm.service_id.$error.required">Select service</span>
        </form>
    Controller:
        function Ctrl($scope) {
          $scope.services = [
            {ServiceID: 1, ServiceName: 'Service1'},
            {ServiceID: 2, ServiceName: 'Service2'},
            {ServiceID: 3, ServiceName: 'Service3'}
          ];
    $scope.save = function(myForm) {
    console.log('Selected Value: '+ myForm.service_id.$modelValue);
    alert('Data Saved! without validate');
    };
        }

这是一个工作的活塞。