1.入门

<form ng-controller="validationController" name="form1" novalidate>
       <p> <input type="submit" ng-disabled="form1.$invalid">     
         <input type="email" name="myemail" ng-model="email"  ng-minlength="10" ng-maxlength="50" required>

        // 使用了 ng-show指令, color:red 在邮件是 $dirty 或 $invalid 才显示。
         <span style="color:red" ng-show="form1.myemail.$dirty && form1.myemail.$invalid">

            <span ng-show="form1.myemail.$error.required">Email is required.</span>
            <span ng-show="form1.myemail.$error.email">Invalid email address.</span>
           <span ng-show="form1.myemail.$error.minlength">min length 10.</span>
           <span ng-show="form1.myemail.$error.maxlength">max length 50.</span>

</span>
       </p>
     </form>

     表单属性 novalidate 用于禁用浏览器默认的验证。
$dirty    表单有填写记录
$valid字段内容合法的
$invalid    字段内容是非法的
$pristine    表单没有填写记录 
 

2.使用angular-messages

<!DOCTYPE html>
<html>
<head>
    <title>Form</title>
     <script type='text/javascript' src='http://cdn.bootcss.com/angular.js/1.4.9/angular.js'></script>
     <script type='text/javascript' src='http://cdn.bootcss.com/angular.js/1.4.9/angular-messages.js'></script>    
    <style type="text/css">
     .form1 {
       transition:all linear 0.5s;
       background: transparent;
     }
    </style>
</head>
<body ng-app="a8_8">
    <form name="form1" ng-controller="form1Controller" class="form1" novalidate>
     <label ng-show="user.id != undefined" ng-model="user.id">
        user id:<span>{{user.id}}</span>
     </label><br>   
     <label>Enter text: <input type="email" ng-model="email1" name="myemail" required  ng-minlength="10"  maxlength="15" /> </label>
      <div style="color:red" ng-messages="form1.myemail.$error" ng-messages-multiple role="alert" ng-if="form1.myemail.$touched">
        <div ng-message="required">Email is required.</div>
        <div ng-message="email">Invalid email address.</div>
        <div ng-message="minlength">min length 10.</div>
        <div ng-message="maxlength">max length 50.</div>        
      </div>
      <p> <input type="submit" value="提交" ng-disabled="form1.$invalid" /></p>   
      <span class="error" ng-show="form1.myemail.$error.required">Required!</span><br>
        <code>form1.myemail.$valid = {{form1.myemail.$valid}}</code><br>
        <code>form1.myemail.$error = {{form1.myemail.$error}}</code><br>
        <code>form1.$valid = {{form1.$valid}}</code><br>
        <code>form1.$error.required = {{!!form1.$error.required}}</code><br>    
     <button ng-click="reset()" ng-disabled="isUnchanged(user)">RESET</button>
     <button ng-click="update(user)" ng-disabled="form1.$invalid || isUnchanged(user)">SAVE</button> <br>
</body>
</html>

3.数据提交

已经不用传统的submit,是基于model 的后台处理

   <script type="text/javascript">

var app = angular.module('a8_8',  ['ngMessages']);
        app.controller('form1Controller', ['$scope',function($scope) {
            $scope.user = {email:'sweet_dreams@aliyun.com'};
            $scope.master = {email:'sweet_dreams@aliyun.com'};
            $scope.update = function(user) {
                if($scope.form1.$valid){
                    alert('通过验证可以提交表单');
                    $scope.master = angular.copy(user);
                    console.log( 'save'+user);     
                    user.id=1;
                    console.log( user);                         
                }else{
                    alert('表单没有通过验证');
                }                 
            };
            $scope.reset = function() {
                $scope.user = angular.copy($scope.master);
            };
            $scope.isUnchanged = function(user) {
                return angular.equals(user, $scope.master);
            };             
         }]);
   </script>

 
 

Angularjs学习笔记5_form1的更多相关文章

  1. AngularJs学习笔记--Forms

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/forms 控件(input.select.textarea)是用户输入数据的一种方式.Form(表单) ...

  2. AngularJs学习笔记--expression

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/expression 表达式(Expressions)是类Javascript的代码片段,通常放置在绑定 ...

  3. AngularJs学习笔记--directive

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/directive Directive是教HTML玩一些新把戏的途径.在DOM编译期间,directiv ...

  4. AngularJs学习笔记--Guide教程系列文章索引

    在很久很久以前,一位前辈向我推荐AngularJs.但当时我没有好好学习,仅仅是讲文档浏览了一次.后来觉醒了……于是下定决心好好理解这系列的文档,并意译出来(英文水平不足……不能说是翻译,有些实在是看 ...

  5. AngularJs学习笔记--bootstrap

    AngularJs学习笔记系列第一篇,希望我可以坚持写下去.本文内容主要来自 http://docs.angularjs.org/guide/ 文档的内容,但也加入些许自己的理解与尝试结果. 一.总括 ...

  6. AngularJs学习笔记--html compiler

    原文再续,书接上回...依旧参考http://code.angularjs.org/1.0.2/docs/guide/compiler 一.总括 Angular的HTML compiler允许开发者自 ...

  7. AngularJs学习笔记--concepts(概念)

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/concepts 继续.. 一.总括 本文主要是angular组件(components)的概览,并说明 ...

  8. AngularJS学习笔记2——AngularJS的初始化

    本文主要介绍AngularJS的自动初始化以及在必要的适合如何手动初始化. Angular <script> Tag 下面通过一小段代码来介绍推荐的自动初始化过程: <!doctyp ...

  9. AngularJs学习笔记--Using $location

    原版地址:http://code.angularjs.org/1.0.2/docs/guide/dev_guide.services.$location 一.What does it do? $loc ...

随机推荐

  1. [POJ 1739] Tony's Tour

    Link: POJ 1739 传送门 Solution: 这题除了一开始的预处理,基本上就是插头$dp$的模板题了 由于插头$dp$求的是$Hamilton$回路,而此题有起点和终点的限制 于是可以构 ...

  2. bzoj 2163: 复杂的大门

    2163: 复杂的大门 Time Limit: 20 Sec  Memory Limit: 259 MBSubmit: 418  Solved: 259[Submit][Status][Discuss ...

  3. 每天一个linux命令12之top

    top命令是Linux下常用的性能分析工具,能够实时显示系统中各个进程的资源占用状况,类似于Windows的任务管理器.下面详细介绍它的使用方法.top是一个动态显示过程,即可以通过用户按键来不断刷新 ...

  4. 数据挖掘经典算法——K-means算法

    算法描述 K-means算法是一种被广泛使用的基于划分的聚类算法,目的是将n个对象会分成k个簇.算法的具体描述如下: 随机选取k个对象作为簇中心: Do 计算所有对象到这k个簇中心的距离,将距离最近的 ...

  5. MAC接普通外置键盘的修改键位的方法

    使用mac电脑已经有一年多,现在对它的喜欢是每天都在增加,甚至有些离不开了.今天突然想接个外置键盘,在使用过程中,遇到一些问题,记录一下. 使用过mac的同学都知道,mac键盘有一个最大的特点是: 比 ...

  6. Wait statistics, or please tell me where it hurts

    https://www.sqlskills.com/blogs/paul/wait-statistics-or-please-tell-me-where-it-hurts/ By: Paul Rand ...

  7. sqlserver 调试WINDBG ---troubleshootingsql.com

    https://troubleshootingsql.com/tag/stack-dump/ Debugging that latch timeout Posted on August 26, 201 ...

  8. 校验知识:CRC32、MD5、SHA1概念及可靠性现状

    转:http://www.metsky.com/archives/337.html 昨天介绍了Windows 7的版本识别问题,不得不提到常用的CRC32.MD5.SHA1等校验算法可靠性问题,如果只 ...

  9. ASP.NET Core 1.0基础之日志

    过年出去玩了一圈,回来继续翻译.前两天偷懒没有翻译,只是转了两篇C# 7计划中的新features,大家还是很支持的.现在继续完善这个系列. 来源https://docs.asp.net/en/lat ...

  10. iOS统计项目的代码总行数

    如果要统计ios开发代码,包括头文件的,CD到项目目录下,命令如下 ① 列出每个文件的行数 find . -name "*.m" -or -name "*.h" ...