BackboneJS - Validar modelo

Descrição

Ele valida o modelo e a entrada fornecida pelo usuário. Se a entrada for inválida, ele retornará uma mensagem de erro especificada ou se a entrada for válida, ele não especifica nada e simplesmente exibe o resultado.

Sintaxe

model.validate(attributes,options)

Parâmetros

  • attributes - Esses atributos definem a propriedade de um modelo.

  • options - Inclui verdadeiro como opção para validar os atributos.

Exemplo

<!DOCTYPE html>
<html>
   <head>
      <title>Model Example</title>
      <script src = "https://code.jquery.com/jquery-2.1.3.min.js"
         type = "text/javascript"></script>
      
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.8.2/underscore-min.js"
         type = "text/javascript"></script>
      
      <script src = "https://cdnjs.cloudflare.com/ajax/libs/backbone.js/1.1.2/backbone-min.js"
         type = "text/javascript"></script>
   </head>
   
   <body>
      <script type = "text/javascript">
         var Person = Backbone.Model.extend ({
            defaults: {
               name: 'john',
               age: 25,
               occupation: 'working'
            },
            initialize : function() {
               this.on("invalid",function(model,error) {
                  document.write(error);
               });
            },
            validate: function(attributes) {
               if ( attributes.age < 25 ) {
                  return 'Person age is less than 25, please enter the correct age!!! ';
               }
               if ( ! attributes.name ) {
                  return 'please enter the name!!!';
               }
            },
         });
         var person = new Person();
         person.on('invalid', function() {
            this.arguments;
         });
         person.set({ age : '20' }, { validate : true });
      </script>
      
   </body>
</html>

Resultado

Vamos realizar as seguintes etapas para ver como funciona o código acima -

  • Salve o código acima no validate.htm Arquivo.

  • Abra este arquivo HTML em um navegador.