表单控制变量
form 控制变量

//字段是否未更改
fromName.inputFieldName.$pristine
//字段是否更改
fromName.inputFieldName.$dirty
//字段有效
fromName.inputFieldName.$valid
//字段无效
fromName.inputFieldName.$invalid
//字段错误信息
fromName.inputFieldName.$error

css样式

ng-valid 表单验证通过时的设置
ng-invalid 表单验证失败时的设置
ng-pristine 表单未被动之前拥有
ng-dirty 表单被动后之后拥有

自定义表单验证

自定义表单验证ngModel属性总结
$parsers     保存了从viewValue向modelValue绑定过程中的处理器函数,它们将来会依次执行
$formatters    保存了从 modelValue向viewValue绑定过程中的处理器函数
$setViewValue  当view发生了某件事情时,从view向model绑定调用$setViewValue把viewValue保存下来
$render      当模型发生变化时,应该怎么去更新视图,从model向view绑定,调用ctrl.$render方法,将viewValue渲染到页面上
$setValidity    设置验证结果
$viewValue     视图的值
$modelValue    模型里的值

$scope绑定事件之$on方法和$emit,$broadcast

function DemoCtrl($scope){
  $scope.count = 0;
  $scope.$on('myevent',function(){
    $scope.count++;
  })
}

视图

//向同级以上dom所在的作用域传递,就是说只有同级以上的dom里访问才能访问到count属性
<button ng-click="$emit('myevent')"></button>
//向同级以下dom所在的作用域传递,同理只有同级以下的dom里访问才能访问到count属性
<button ng-click="$broadcast('myevent')"></button>

利用ngModel相关属性及方法自定义表单验证指令
ngModel里的属性总结 已经在上面提到了
下面这是一个 只能输入偶数的验证指令(自定义表单验证 $setValidaity )

angular关于表单指令的汇总

input 属性
  name
  ng-model
  ng-required
  ng-minlength
  ng-maxlength
  ng-pattern 匹配模式
  ng-change 值变化时的回调

ngModelController的方法和属性的使用

ngModelController方法

$render();
  当视图需要更新的时候会被调用。使用ng-model的指令应该自行实现这个方法。

$isEmpty(value);
  该方法用于判断输入值是否为空。
  例如,使用ngModelController的指令需要判断其中是否有输入值的时候会使用该方法。该方法可用来判断值是否为undefined,'',null或者NaN。
  你可以根据自己的需要重载该方法。

$setValidity(validationErrorKey, isValid);
  该方法用于改变验证状态,以及在控制变化的验证标准时通知表格。
  这个方法应该由一个验证器来调用。例如,一个解析器或者格式化函数。

$setPristine();
  该方法用于设置控制到原始状态。
  该方法可以移除'ng-dirty'类并将控制恢复到原始状态('ng-pristine'类)。

$cancelUpdate();
  该方法用于取消一次更新并重置输入元素的值以防止$viewCalue发生更新,它会由一个pending debounced事件引发或者是因为input输入框要等待一些未来的事件。

  如果你有一个使用了ng-model-options指令的输入框,并为它设置了debounced事件或者是类似于blur的事件,那么你可能会碰到在某一段时间内输入框中值和ngModel的$viewValue属性没有保持同步的情况。
  在这种情况下,如果你试着在debounced/future事件发生之前更新ngModel的$modelValue,你很有可能遇到困难,因为AngularJS的dirty cheching机制实际上并不会分辨一个模型究竟有没有发生变化。
  $cancelUpdate()方法应该在改变一个输入框的model之前被调用。
  记住,这很重要因为这能够确保输入字段能够被新的model值更新,而pending操作将会被取消。

ngModelController中的属性

$viewValue
  视图中的实际值

$modelValue
  model中的值,它金额控制器绑定在一起

$parsers
  将要执行的函数的数组,无论什么时候控制器从DOM中读取了一个值,它都将作为一个管道。其中的函数依次被调用,并将结果传递给下一个。最后出来的值将会被传递到model中。其中将包括验证和转换值的过程。

  对于验证步骤,这个解析器将会使用$setValidity方法,对于不合格的值将返回undefined。

$formatters
  一个包含即将执行函数的数组,无论什么时候model的值发生了变化,它都会作为一个管道。其中的每一个函数都被依次调用,并将结果传递给下一个函数。该函数用于将模型传递给视图的值进行格式化。

$viewChangeListeners
  只要视图的值发生变化,其中的函数就会被执行。其中的函数执行并不带参数,它的返回值也会被忽略。它可以被用在额外的#watches中。

$error
  一个包含所有error的对象

$pristine
  如果用户还没有进行过交互,值是true。

$dirty
  如果用户已经进行过交互,值是true。

$valid
  如果没有错误,值是true。

$invalid
  如果有错误,值是true。

指令与控制器交互和复用

指令是用来复用的是用来生成UI组件的。

angualrjs 总结 随记(二)的更多相关文章

  1. h5 录音 自动生成proto Js语句 UglifyJS-- 对你的js做了什么 【原码笔记】-- protobuf.js 与 Long.js 【微信开发】-- 发送模板消息 能编程与会编程 vue2入坑随记(二) -- 自定义动态组件 微信上传图片

    得益于前辈的分享,做了一个h5录音的demo.效果图如下: 点击开始录音会先弹出确认框: 首次确认允许后,再次录音不需要再确认,但如果用户点击禁止,则无法录音: 点击发送 将录音内容发送到对话框中.点 ...

  2. Java入门记(二):向上转型与向下转型

    在对Java学习的过程中,对于转型这种操作比较迷茫,特总结出了此文.例子参考了<Java编程思想>. 目录 几个同义词 向上转型与向下转型 例一:向上转型,调用指定的父类方法 例二:向上转 ...

  3. vue2入坑随记(二) -- 自定义动态组件

    学习了Vue全家桶和一些UI基本够用了,但是用元素的方式使用组件还是不够灵活,比如我们需要通过js代码直接调用组件,而不是每次在页面上通过属性去控制组件的表现.下面讲一下如何定义动态组件. Vue.e ...

  4. epclise设置tomcat方法(步骤)(菜鸟巧记二)

    epclise设置tomcat 1.打开epclise→window→preferences 2.输入server,打开server→runtime environments→选择add新建 3.打开 ...

  5. 【React踩坑记二】react项目实现JS路由跳转

    这里使用的是4.31版本的react-router-dom "react-router-dom": "^4.3.1", 直接使用以下代码即可实现路由跳转 thi ...

  6. 菜鸟类库诞生记二:通过反射转换DataRow为对象

    虽然大数据量的环境下,通过反射转换DataRow为对象性能会很低,但是在数据量适中的时候,这样能够减少很多的代码量,性能也确实不错. 所以在数据量不是很大的情况下,推荐使用. 如果数据量很大,可以使用 ...

  7. ORACLE DATAGURARD 折腾记二

    前文再续,书接上一回,这次折腾Data Guard的一个重要目的是利用switchover实现机器的升级,怎么switchover呢?按照我的理解,Data Guard的角色切换是这样一个过程: (1 ...

  8. crm踩坑记(二)

    Linux tmux 如何查看 tmux如何进行滚动呢? prefix + [, prefix为tmux的前置动作,默认是ctrl + b. 使用方向键或者pageUp来进行翻页. q可以退出滚动模式 ...

  9. (NO.00003)iOS游戏简单的机器人投射游戏成形记(二十一)

    回到Xcode中,在MainScene.h接口中添加碰撞协议: @interface MainScene : CCNode <CCPhysicsCollisionDelegate> //. ...

随机推荐

  1. springboot 不同类型多数据源配置及使用

    springboot多数据源配置: datasource.master.jdbc=jdbc:mysql://localhost:3306/test?useUnicode=true&charac ...

  2. Python---6条件判断与循环

    条件判断 计算机之所以能做很多自动化的任务,因为它可以自己做条件判断. 比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,用if语句实现: age = 20 if age >= ...

  3. Python不使用元类创建缓存实例

    问题 当创建类实例时我们想返回一个缓存引用,让其指向上一个用同样参数(如果有的话)创建出来的类实例. 这个问题常常出现在当我们想确保针对一组输入参数只会有一个类实例存在时. 解决方法: 使用一个与类本 ...

  4. Bitstream or PCM?

    背景 提问 讨论精选 一 二 三 四 五 最后 电视上同轴输出的做法. 背景 USB通道下播放声音格式为AAC的视频文件,同轴输出设置为Auto,功放没有声音,设置成PCM,有声音. 提问 Auto/ ...

  5. PHP正则表达式-修饰符

    我们在PHP正则表达式的学习中会碰到修饰符,那么关于PHP正则表达式修饰符的理解以及使用我们需要注意什么呢?那么我们来具体的看看它的概念以及相关内容.在学习PHP正则表达式修饰符之前先来理解下贪婪模式 ...

  6. Mysql(或者sqlite), Mongo中update Column + 1

    Mysql(或者sqlite), Mongo中update Column + 1 有类似以下需求,在数据库表里有一个字段,记录了一个count,然后又时候需要在count的基础上加上某个数字,比如1. ...

  7. PHP manual-mysqli-connections-翻译

    PHP manual-mysqli-connections MySQL服务器支持使用不同的传输层进行连接. 连接可以使用TCP / IP,Unix域套接字或Windows命名管道. 主机名localh ...

  8. Alberto Del Bimbo:为什么说研究员要有想象力?

    ​ Del Bimbo:为什么说研究员要有想象力?" title="Alberto Del Bimbo:为什么说研究员要有想象力?"> ​ 说到科研,与日本式的&q ...

  9. 带你学习ES5中新增的方法

    1. ES5中新增了一些方法,可以很方便的操作数组或者字符串,这些方法主要包括以下几个方面 数组方法 字符串方法 对象方法 2. 数组方法 迭代遍历方法:forEach().map().filter( ...

  10. 【WPF学习】第五十三章 动画类型回顾

    创建动画面临的第一个挑战是为动画选择正确的属性.期望的结果(例如,在窗口中移动元素)与需要使用的属性(在这种情况下是Canvas.Left和Canvas.Top属性)之间的关系并不总是很直观.下面是一 ...