Angularjs学习笔记5_form1

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:‘[email protected]‘};
            $scope.master = {email:‘[email protected]‘};
            $scope.update = function(user) {
                $scope.master = angular.copy(user);
                console.log( ‘save‘+user);     
                user.id=1;
                console.log( user);                   
            };
            $scope.reset = function() {
                $scope.user = angular.copy($scope.master);
            };
            $scope.isUnchanged = function(user) {
                return angular.equals(user, $scope.master);
            };             
         }]);
   </script>
 
 
时间: 2024-11-02 08:19:58

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

angularjs学习笔记—事件指令

angularjs学习笔记—事件指令 小俞 4.4k 3月30日 发布 推荐 4 推荐 收藏 17 收藏,11.1k 浏览 ngClick 适用标签:所有触发条件:单击 #html <div ng-controller="LearnCtrl"> <div ng-click="click()">click me</div> <button ng-click="click()">click me<

angularjs 学习笔记(一) -----JSONP跨站访问

1.  下载angular-seed-master-master包,解压缩后将新版本的angularJS文件放入其中. 2.  制作frontmockup文件夹(前端调用),同时制作backmockup文件夹(后端调用),使用IIS开启2个webserver(此步骤可以用其他方式替代). 3.  backmockup站点添加以下HTTP头 Access-Control-Allow-Credentials:true Access-Control-Allow-Headers:origin,x-req

angularjs 学习笔记 -----结构定义

1.  Module使用方法 var APP =angular.module('fontApp',['ngResource', 'ngRoute', 'ngSanitize']); APP为定义的别名,之后的调用都应尽量使用该别名 'fontApp' ng-app="fontApp" 新版本angular中route被分离出来,各个被使用的Providerdou需要在此处声明. 大型应用应该拆分模块来做,先定义一个服务模块,然后再加载它 angular.module('xmpl.ser

angularjs 学习笔记(二) ----- bootstrap框架

1.  下载新的jquery-1.11.1文件. 2.  下载新的bootstrap文件. 3.  选择流式布局的模板填充入index.html文件. 4.  将top.foot转为nginclude文件 nginclude必须使用$scope对象,因此需要设置一个全局的mainctrl来将字符串或全局变量注入$cope中. $rootScope.global =global; 直接将全局变量global赋值给$rootScope,并且之后的子$Scope会获得继承,静态定义与ctrl分开. 5

-_-#AngularJS学习笔记

AngularJS学习笔记 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> </head> <body> <style> .done{display:none} .ignore{color:#999} </style> <ul> <li class="

AngularJs学习笔记--directive

原版地址:http://code.angularjs.org/1.0.2/docs/guide/directive Directive是教HTML玩一些新把戏的途径.在DOM编译期间,directives匹配HTML并执行.这允许directive注册行为或者转换DOM结构. Angular自带一组内置的directive,对于建立Web App有很大帮助.继续扩展的话,可以在HTML定义领域特定语言(domain specific language ,DSL). 一.在HTML中引用direc

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

在很久很久以前,一位前辈向我推荐AngularJs.但当时我没有好好学习,仅仅是讲文档浏览了一次.后来觉醒了……于是下定决心好好理解这系列的文档,并意译出来(英文水平不足……不能说是翻译,有些实在是看不懂,希望大家在参观的过程中指出其中的错误).经过1个多月断断续续的努力,终于把Guide里面的文章基本上都弄出来.Guide中的部分章节,由于重复的部分似乎有点多,而且篇幅较短,这里就没有列出来. 文章列表如下: AngularJs学习笔记--bootstrap AngularJs学习笔记--ht

AngularJS学习笔记filter

filter是对数据进行过滤操作,比如按某个字段搜索.格式化数据等等,是一个非常有用的接口.下面就简单介绍下它的用法. AngularJS自带的filter接口,|是filter的分隔符,参数用:分隔: currency,格式化number,货币化,默认是转化成美元  param(number,symbol),返回值将会把数字每3位加一个逗号 <input type="number" ng-model="amount"/> <p>默认美元:{

AngularJS 学习笔记 -- 指令(Directive)

AngularJS 指令学习笔记 AngularJS怎样处理指令其实是依赖于指令定义时返回的对象属性的,所以要想深入理解如何定义一个指令,首相需要理解指令定义时各个参数的含义. 完整的AngularJS指令参数 angular.module('app', []) .directive('demoDirective', function (){ // 依据官方规范,指令的定义时应该严格遵循驼峰式命名规则,使用时采用'-'连接单词 return { restrict : String in ['E'