先上效果页面:https://lpdong.github.io/myForm-1/

其中几个知识点

1、angularJs提供了几个新的type类型:

type="password"

type="email"

type="number"

type="url"

2、几个参数含义

ng-required      //是否必填,true/false

ng-minlength     //最小长度,数字

ng-maxlength     //最大长度,数字

min              //最小数字,数字,仅在type="number"下

max              //最小数字,数字,仅在type="number"

3、几个form控制变量,先来一段代码

<form role="form" name="myform" >
<div class="form-group" >
<label class="col-sm-2">用户名</label>
<div class="col-sm-8">
<input type="text" name="username" class="form-control" placeholder="请输入用户名"></div>
</div>
</form>
formName.inputFieldName.$pristine         //字段是否未更改,对应上面的html代码即为 myform.username.$pristine

formName.inputFieldName.$dirty            //字段是否更改,对应上面的html代码即为 myform.username.$dirty

formName.inputFieldName.$valid            //字段有效,对应上面的html代码即为 myform.username.$valid

formName.inputFieldName.$invalid          //字段无效,对应上面的html代码即为 myform.username.$invalid

formName.inputFieldName.$error            //字段错误信息,使用频率比较高,对应上面的html代码即为 myform.username.$error

4、下面直接上代码,首先是html代码,使用了bootstrap.css样式,在结尾引入了angular

<!DOCTYPE html>
<html>
<head>
<title>form验证</title>
<link rel="stylesheet" type="text/css" href="style/bootstrap.css">
</head>
<body ng-app="formModule">
<div style="margin-top: 60px;">
<form role="form" name="myform" class="form-horizontal container" ng-controller="formctrl">
<!-- 用户名 -->
<div class="form-group" ng-class="{'has-error':myform.username.$dirty && myform.username.$invalid}">
<label class="col-sm-2">用户名</label>
<div class="col-sm-8">
<input type="text" name="username" ng-minlength="5" ng-maxlength="10" ng-required="true" ng-model="data.username" class="form-control" placeholder="请输入用户名"></div>
<div class="col-sm-2 text-danger" ng-show="myform.username.$error.minlength">用户名必须大于5位</div>
<div class="col-sm-2" ng-show="myform.username.$error.maxlength">用户名必须小于于10位</div>
</div>
<!-- 密码 -->
<div class="form-group" ng-class="{'has-error':myform.password.$dirty&&myform.password.$invalid}">
<label class="col-sm-2">密 码</label>
<div class="col-sm-8">
<input type="password" name="password" ng-minlength="10" ng-required="true" ng-model="data.password" class="form-control" placeholder="请输入密码"></div>
<div class="col-sm-2 text-danger" ng-show="myform.password.$error.minlength">密码必须大于10位</div>
</div> <!-- 确认密码 -->
<div class="form-group" ng-class="{'has-error':myform.passwordconfirm.$dirty&&myform.passwordconfirm.$invalid}">
<label class="col-sm-2">确认密码</label>
<div class="col-sm-8">
<input type="password" name="passwordconfirm" ng-required="true" ng-model="data.passwordconfirm" class="form-control" placeholder="请输入确认密码"></div>
<div class="col-sm-2 text-danger" ng-show="data.passwordconfirm!=data.password&&myform.password.$dirty&&myform.passwordconfirm.$dirty">两次密码不一致</div>
</div>
<!-- 邮箱 -->
<div class="form-group" ng-class="{'has-error':myform.email.$dirty&&myform.email.$invalid}">
<label class="col-sm-2">邮 箱</label>
<div class="col-sm-8">
<input type="email" name="email" ng-required="true" ng-model="data.email" class="form-control" placeholder="请输入邮箱地址"></div>
<div class="col-sm-2 text-danger" ng-show="myform.email.$error.email">请输入正确邮箱地址</div>
</div>
<!-- 博客 -->
<div class="form-group" ng-class="{'has-error':myform.age.$dirty&&myform.age.$invalid}">
<label class="col-sm-2">年 龄</label>
<div class="col-sm-8">
<input type="number" name="age" ng-required="true" min="10" max="99" ng-model="data.age" class="form-control" placeholder="请输入您的年龄"></div>
<div class="col-sm-2 text-danger" ng-show="myform.age.$error.min&&myform.age$error.max">请输入正确年龄</div>
</div>
<!-- 年龄 -->
<div class="form-group" ng-class="{'has-error':myform.blog.$dirty&&myform.blog.$invalid}">
<label class="col-sm-2">博 客</label>
<div class="col-sm-8">
<input type="url" name="blog" ng-required="true" ng-model="data.blog" class="form-control" placeholder="请输入博客地址"></div>
<div class="col-sm-2 text-danger" ng-show="myform.blog.$error.url">请输入正确博客地址</div>
</div>
<!-- 性别 -->
<div class="form-group">
<label class="col-sm-2">性 别</label>
<div class="col-sm-8">
<label class="radio-inline">
<input type="radio" value="1" ng-model="data.sex" name="sex"> 男</label>
<label class="radio-inline">
<input type="radio" value="2" ng-model="data.sex" name="sex"> 女</label>
</div>
</div>
<!-- 爱好 -->
<div class="form-group">
<label class="col-sm-2">爱 好</label>
<div class="col-sm-8">
<label ng-repeat="hoppy in hoppies" class="checkbox-inline">
<input type="checkbox" name="hoppy[]" ng-click="togglehoppy()" ng-model="hoppy.checked" >{{hoppy.name}}
</label>
</div>
<div class="col-sm-2">{{data.Ahoppy.join('、')}}</div>
</div> <!-- 地址 -->
<div class="form-group">
<label class="col-sm-2">地 址</label>
<div class="col-sm-3">
<select class="form-control" ng-model="data.provinec" ng-options="x.id as x.name for x in cities | cityfilter:0"></select>
</div>
<div class="col-sm-3">
<select class="form-control" ng-show="data.provinec" ng-model="data.area" ng-options="x.id as x.name for x in cities | cityfilter:data.provinec"></select>
</div>
<div class="col-sm-3">
<select class="form-control" ng-show="data.area" ng-model="data.city" ng-options="x.id as x.name for x in cities | cityfilter:data.area"></select>
</div>
</div>
</form>
</div> <script src="js/angular.js"></script>
<script src="js/app.js"></script>
</body>
</html>

下面为js代码(可能其中有些不妥之处,请指正,谢谢)

(function(window) {
'use strict';
var mymodule = angular.module('formModule', []);
// 城市删选器
mymodule.filter('cityfilter',function(){
return function(data,parent){
var cityData=[];
angular.forEach(data, function(item, key){
if(item.parent==parent){
cityData.push(item);
}
});
return cityData;
}
});
mymodule.controller('formctrl', ['$scope', function($scope) {
// 设定初始状态
$scope.data={
Ahoppy:[1,3]
}
// 爱好对象
$scope.hoppies = [
{id: 1,name: '玩游戏',checked: istrue(1)},
{id: 2,name: '吃饭',checked: false},
{id: 3,name: '睡觉',checked: false},
{id: 4,name: '玩游戏',checked: true}
];
// 城市
$scope.cities=[
{name:'河南',parent:0,id:1},
{name:'郑州',parent:1,id:2},
{name:'郑东新区',parent:2,id:3},
{name:'金水区',parent:2,id:4},
{name:'二七区',parent:2,id:5},
{name:'信阳',parent:1,id:6},
{name:'商城',parent:6,id:7},
{name:'罗山',parent:6,id:8},
{name:'杭州',parent:0,id:9},
{name:'西湖区',parent:9,id:10},
{name:'余杭区',parent:9,id:11},
{name:'萧山区',parent:9,id:12},
{name:'上城区',parent:9,id:13},
]; // 判断是否是选中状态
function istrue(id){
for(var i=0;i<$scope.data.Ahoppy.length;i++){
if($scope.data.Ahoppy[i]===id){
return true;
}
}
return false;
};
// 获取选中的爱好 $scope.togglehoppy = function() {
$scope.data.Ahoppy = [];
angular.forEach($scope.hoppies, function(item, key) {
if (item.checked == true) {
$scope.data.Ahoppy.push(item.id);
}
});
} }])
})(window)

angular实现form验证的更多相关文章

  1. Nodejs之MEAN栈开发(四)---- form验证及图片上传

    这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能.开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R ...

  2. form验证及图片上传

    form验证及图片上传 这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能.开始之前需要源码同学可以先在git上fork:https://github.com/ ...

  3. Angular 表单验证类库 ngx-validator 1.0 正式发布

    背景介绍 之前写了一篇 <如何优雅的使用 Angular 表单验证>,结尾处介绍了统一验证反馈的类库  ngx-validator  ,由于这段时间一直在新模块做微前端以及相关业务组件库, ...

  4. Asp.Net Form验证不通过,重复登录

    问题产生根源: 当然,其实应该需要保持线上所有机器环境一致!可是,写了一个小程序.使用的是4.5,aysnc/await实在太好用了,真心不想把代码修改回去. so,动了念头,在这台服务器上装个4.5 ...

  5. tornado web高级开发项目之抽屉官网的页面登陆验证、form验证、点赞、评论、文章分页处理、发送邮箱验证码、登陆验证码、注册、发布文章、上传图片

    本博文将一步步带领你实现抽屉官网的各种功能:包括登陆.注册.发送邮箱验证码.登陆验证码.页面登陆验证.发布文章.上传图片.form验证.点赞.评论.文章分页处理以及基于tornado的后端和ajax的 ...

  6. Python Django的分页,Form验证,中间件

    本节内容 Django的分页 Form 中间件 1 Django 分页 1.1 Django自带的分页 1.首先来看下我的测试数据环境 ############ models.py ######### ...

  7. Django中Form验证

    Django的Form主要具有一下几大功能: 生成HTML标签 验证用户数据(显示错误信息) HTML Form提交保留上次提交数据 初始化页面显示内容 一,Form验证 第一种操作:主要是这三个函数 ...

  8. Django form验证

    # 模版 class LoginForm(forms.Form): # 模版中的元素 user = forms.CharField(min_length=6,error_messages={" ...

  9. python自动化开发-[第二十一天]-form验证,中间件,缓存,信号,admin后台

    今日概要: 1.form表单进阶 2.中间件 3.缓存 4.信号 5.admin后台 上节课回顾 FBV,CBV 序列化 - Django内置 - json.dumps(xxx,cls=) Form验 ...

随机推荐

  1. Python之路: socket篇

    (默认)与特定的地址家族相关的协议,如果是  ,则系统就会根据地址格式和套接类别,自动选择一个合适的协议 sk import socketip_port = ()sk = socket.socket( ...

  2. 为什么说Neutron不是SDN?

    http://vuejs.com.cn/ 这里面有个canvans 画图的js 代码.有意思,研究一下. Neutron 介绍:https://www.ibm.com/developerworks/c ...

  3. 移动WEB模拟原声APP滑动删除

    移动WEB模拟原声APP滑动删除 效果 代码 <!DOCTYPE html> <html lang="en"> <head> <meta ...

  4. svn + jenkins + maven 实现java环境的自动化构建和部署

    1. 环境说明: 系统CentOS 7 x64 IP:  10.6.0.126 1.1 首先安装配置 svn Centos 7  通过yum 安装svn 既可, 版本为1.7.14 # yum -y ...

  5. javascript 巴西世界杯倒计时

    巴西世界杯是足球迷的今年最终关注的事情,做为球迷的我也不例外,自己做了一个巴西世界杯的倒计时. <!DOCTYPE html> <html> <head> < ...

  6. fedora安装各种应用软件

    1 安装视频播放器 sudo yum install mplayer mplayer-gui 可以从命令行 和 gnome 中启动 2 音量调节 (1)使用 alsamixer alsamixer是一 ...

  7. 用于ARM上的FFT与IFFT源代码(C语言,不依赖特定平台)(转)

    源:用于ARM上的FFT与IFFT源代码(C语言,不依赖特定平台) 代码在2011年全国电子大赛结束后(2011年9月3日)发布,多个版本,注释详细. /*********************** ...

  8. stm32驱动DS1302芯片

    天时可以自动调整,且具有闰年补偿功能.工作电压宽达2.5-5.5V.采用双电源供电(主电源和备用电源),可设置备用电源充电方式,提供了对后背电源进行涓细电流充电的能力.DS1302的外部引脚分配如下图 ...

  9. Uber广州车主官网本周将暂关闭

    Uber广州车主官网本周将暂关闭 http://news.southcn.com/g/2015-05/04/content_123509931.htm

  10. cocos2d-x 定时器selector的使用 :schedule的使用

    在游戏设计时,我们需要不断的改变屏幕显示来反映游戏操作的效果,最简单的就是提示用户已经进行的游戏时间.为此,我们需要使用cocos2d-x内置的任务调度机制,即CCNode的schedule成员函数. ...