angular 基于ng-messages的表单验证实例


Posted in Javascript onMay 04, 2017

最近在学习angular,那么今天也算个学习笔记吧!

html

<div class="form-group" ng-class="{'has-error': myForm.myName.$touched && myForm.myName.$invalid}">
  <label class="col-xs-2 control-label">name</label>
  <div class="col-xs-6">
    <input type="text" class="form-control" name="myName" ng-model="formData.username"
        placeholder="2-10个中英文字符,aaa会重名,必填"
        name-check minlength="2" maxlength="10" required>
  </div>
  <div class="col-xs-4 form-control-static text-danger" ng-messages="myForm.myName.$error"
           ng-messages-include="demos/form/error.html" ng-show="myForm.myName.$touched">
  </div>
</div>

ng-messages="myForm.myName.$error" 给出错误类型(required, char, exist, minlength)

error.html

<span ng-message="required">必填</span>
<span ng-message="char">非法字符</span>
<span ng-message="exist">名称已存在</span>
<span ng-message="minlength">太短了</span>

directive name-check 利用ngModel 的$validators,& $asyncValidators 添加自定义验证

app.directive('nameCheck', nameCheck);

nameCheck.$inject = ['HttpService', '$q'];

function nameCheck(HttpService, $q){

  var NAME_REG = /^[a-zA-Z\u4e00-\u9fa5]+$/;

  return {
    restrict: 'A',
    require: 'ngModel',
    link:function($scope,element,attrs,ctrl){

      ctrl.$validators.char = function(modelValue, viewValue) {
        var value = modelValue || viewValue;
        if(!NAME_REG.test(value)){
          return false;
        }
        return true;
      };
      ctrl.$asyncValidators.exist = function(modelValue, viewValue){
        var value = modelValue || viewValue;
        var deferred = $q.defer();
        HttpService.get('api/users/' + value).then(function(res) {
          if(res.isExist){
            deferred.reject(false);

          }
          deferred.resolve(true);
        })

        return deferred.promise;
      }
    }
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript 遍历验证所有文本框的值
Aug 27 Javascript
Javascript中的相等与不等运算
Apr 25 Javascript
一个小例子解释如何来阻止Jquery事件冒泡
Jul 17 Javascript
深入分析Cookie的安全性问题
Mar 01 Javascript
js实现鼠标经过表格行变色的方法
May 12 Javascript
jQuery插件echarts设置折线图中折线线条颜色和折线点颜色的方法
Mar 03 Javascript
微信小程序 action-sheet 反馈上拉菜单简单实例
May 11 Javascript
vue服务端渲染的实例代码
Aug 28 Javascript
js处理包含中文的字符串实例
Oct 11 Javascript
垃圾回收器的相关知识点总结
May 13 Javascript
深入浅析AngularJs模版与v-bind
Jul 06 Javascript
比较node.js和Deno
Apr 27 Javascript
JS实现标签页切换效果
May 04 #Javascript
ES6下React组件的写法示例代码
May 04 #Javascript
JS触摸事件、手势事件详解
May 04 #Javascript
详解Angular 4.x Injector
May 04 #Javascript
详解Vue中使用v-for语句抛出错误的解决方案
May 04 #Javascript
详解Node.js串行化流程控制
May 04 #Javascript
纯原生js实现贪吃蛇游戏
Apr 16 #Javascript
You might like
thinkPHP5.0框架自动加载机制分析
2017/03/18 PHP
模仿jQuery each函数的链式调用
2009/07/22 Javascript
JS编程小常识很有用
2012/11/26 Javascript
设为首页和收藏的Javascript代码(亲测兼容IE,Firefox,chrome等浏览器)
2013/11/18 Javascript
JQuery操作iframe父页面与子页面的元素与方法(实例讲解)
2013/11/20 Javascript
jquery删除数据记录时的弹出提示效果
2014/05/06 Javascript
使用命令对象代替switch语句的写法示例
2015/02/28 Javascript
JQuery实现简单的图片滑动切换特效
2015/11/22 Javascript
js数组实现权重概率分配
2017/09/12 Javascript
JavaScript实现带有子菜单和控件的slider轮播图效果
2017/11/01 Javascript
Vue组件的使用教程详解
2018/01/05 Javascript
JS中touchstart事件与click事件冲突的解决方法
2018/03/12 Javascript
Vue数据绑定简析小结
2019/05/07 Javascript
nodejs二进制与Buffer的介绍与使用
2019/07/11 NodeJs
深入理解 ES6中的 Reflect用法
2020/07/18 Javascript
[59:32]Liquid vs Fnatic 2019国际邀请赛淘汰赛败者组BO1 8.20.mp4
2020/07/19 DOTA
python之模拟鼠标键盘动作具体实现
2013/12/30 Python
python变量不能以数字打头详解
2016/07/06 Python
python实现飞机大战微信小游戏
2020/03/21 Python
python 处理string到hex脚本的方法
2018/10/26 Python
在python中画正态分布图像的实例
2019/07/08 Python
python实现的登录与提交表单数据功能示例
2019/09/25 Python
pytorch 图像预处理之减去均值,除以方差的实例
2020/01/02 Python
Python进程间通信multiprocess代码实例
2020/03/18 Python
HTML5 placeholder属性详解
2016/06/22 HTML / CSS
百思买美国官网:Best Buy
2016/07/28 全球购物
FLOS美国官网:意大利高级照明工艺的传奇
2018/08/07 全球购物
SEPHORA丝芙兰捷克官网:购买香水、化妆品和护肤品
2018/11/26 全球购物
什么是符号链接,什么是硬链接?符号链接与硬链接的区别是什么?
2014/01/19 面试题
倡议书范文格式
2014/05/12 职场文书
优秀应届毕业生自荐书
2014/06/29 职场文书
后备干部推荐材料
2014/12/24 职场文书
预备党员群众意见
2015/06/01 职场文书
投诉信回复范文
2015/07/03 职场文书
MySQL 1130异常,无法远程登录解决方案详解
2021/08/23 MySQL
BCL经典机 SONY ICF-5900W电路分析
2022/04/24 无线电