English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

Exemplo de Funcionalidade de Validação Simples do Angular

Este exemplo ilustra a função de validação simples do Angular. Partilho com vocês para referência, conforme o seguinte detalhamento:

Vamos ver primeiro o efeito de execução:

Código de exemplo completo a seguir:

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8">
    <title>pt.oldtoolbag.com função de validação Angular</title>
    <script src="angular.min.js"></script>
    <style>
      input{
        display: block;
      }
      ul li{
        color: red;
      }
    </style>
    <script>
      angular.module("myapp",[])
      .controller("demoC",function($scope){
        $scope.datas = [{
            id: 10011120,
            name: "iphoneX",
            num: 99
          },
          {
            id: 10011121,
            name: "华为mate10",
            num: 20
          },
          {
            id: 10011122,
            name: "vivoR12",
            num: 55
          }
        ]; //定义一个数组
        $scope.save=function(){
          //创建一个存放错误信息数组
          $scope.error_val=[];
          var reg_id=/^\d{8,8}$/; //只能8位数字
          if(!reg_id.test($scope.id)){
            $scope.error_val.push("资产编号格式,必须为数字,且长度为8位");
          }
          //资产名称
          if($scope.name==undefined||$scope.name==""){
            $scope.error_val.push("资产名称不能为空!");
          }
            for(var i in $scope.datas){
              if($scope.name==$scope.datas[i].name){
                $scope.error_val.push("资产名称已经存在");
                break; //结束循环,已经查找到资产名称不合法
              }
            }
          }
          //资产数量
          var reg_num=/^\d{1,}$/; //只能8位数字
          $scope.error_val.push("资产编号数量,必须为数字");
            else{
          }
            if($scope.num<=0){
              $scope.error_val.push("资产编号数量必须大于0");
            }
          }
          //何时添加进行,何时不添加
          if($scope.error_val.length==0){
            $scope.datas.push({
              id:$scope.id,
              name:$scope.name,
              num:$scope.num
            });
          }
        }
      })
    </script>
  </head>
  <body ng-app="myapp" ng-controller="demoC">
    <table border="1px solid">
      <tr>
        <td>Número do ativo</td>
        <td>Nome do ativo</td>
        <td>Quantidade de ativos</td>
      </tr>
      <tr ng-repeat="d in datas">
        <td>{{d.id}}</td>
        <td>{{d.name}}</td>
        <td>{{d.num}}</td>
      </tr>
    </table>
    <div>
      <form>
        Número do ativo<input ng-model="id" />
        Nome do ativo<input ng-model="name" />
        Quantidade de ativos<input ng-model="num" />
        <div>
          <ul>
            <li ng-repeat="e in error_val">
              {{e}}
            </li>
          </ul>
        </div>
        <button ng-click="save()">
        Registro de ativos  
        </button>
      </form>
    </div>
  </body>
</html>

PS: Aqui temos mais2Uma ferramenta muito conveniente de expressões regulares para referência e uso:

Ferramenta online de teste de expressões regulares do JavaScript:
http://tools.jb51.net/regex/javascript

Ferramenta online de geração de expressões regulares:
http://tools.jb51.net/regex/create_reg

Leitores interessados em mais conteúdo sobre AngularJS podem consultar as seções especiais deste site: 'Resumo de Técnicas de Manipulação de Directivas AngularJS', 'Tutorial de Início e Avançado AngularJS' e 'Resumo da Arquitetura MVC AngularJS'.

Espero que o conteúdo deste artigo ajude a todos na programação de AngularJS.

Declaração: O conteúdo deste artigo é extraído da Internet, pertence ao respectivo proprietário, fornecido voluntariamente pelos usuários da Internet e carregado automaticamente. Este site não possui direitos de propriedade, não foi editado manualmente e não assume responsabilidade por eventuais responsabilidades legais. Se você encontrar conteúdo suspeito de violação de direitos autorais, por favor, envie e-mail para: notice#oldtoolbag.com (ao enviar e-mail, substitua # por @ para denunciar e forneça provas relevantes. Se confirmado, o site deletará imediatamente o conteúdo suspeito de violação de direitos autorais.)

Você Também Pode Gostar