angular.js - ng-pattern 验证问题
问题描述
$scope.regex = /^1[34578]d{9}$/;
1.对手机号进行了验证2.现在添加的时候会进行验证3.但是编辑的时候,如果之前的手机号填写有错,不会提示,这样保存的时候会出错。保存时是这样判断的
问题解答
回答1:要想要 input输入的时候验证 + form提交的时候验证:第一步:给要验证的 input 添加 onkeyup 事件,在键盘松开的时候触发验证第二步:给 form 添加 onsubmit 事件,在表单提交的时候做验证
下面是一个范例:HTML:
<form action=’url’ id=’login_form’> 手机号:<input type=’number’ name=’phone’ /> 提交:<input type=’submit’ value=’提交’ /></form>
Javascript
var form = document.forms[’login_form’]var phoneNum = form.elements[’phone’];var phoneReg = /^1[34578]d{9}$/;// 检测手机号码var checkUserPhoneNum = function(){ var phoneVal = phoneNum.value;// 表单验证 if (!phoneReg.test(phoneVal)) {return false; }return true;};// 手机号码输入的时候验证phoneNum.onkeyup = function(){ if (!checkUserPhoneNum()){// 手机号码不正确的时候要做的事情....return ; }// 手机号码正确的时候要做的事情....};// 表单提交form.onsubmit = function(event){ // 首先阻止表单提交 event.preventDefault();// 手机号码验证 if (!checkUserPhoneNum()){console.log(’请输入正确的11位手机号码’);return ; } // 通过验证,则提交表单 this.submit();};回答2:
可以改成:
if ($scope.userform.$dirty && $scope.userform.$invalid) {}
其实当无任何变更时 $scope.userform.$dirty 时不允许提交,这也算是合理的。
========UPDATE========
你的form写法有很大的问题。
angular自带html5属性的验证模型angular表单自身是包含着大部分html5表单元素的验证,比如:required。要想启用它,需要给from加上 ng-submit='adduserinfo()',既然有验证模型,那就去掉浏览器自身的验证,再加上 novalidate。
既然表单加上提交动作,那么确定按钮就不需要任何跟事件有关的东西了。
<form name='userform' novalidate ng-submit='adduserinfo()' id='user_form'> <button type='submit'>确定</button></form>
其实angular自身的验证模型还是非常丰富,特别是有正则表达式,可以做的事非常多。
回答3:试试把ng-pattern='/^1/'(你写的regex)直接写在界面上 不要用变量定义
相关文章:
1. angular.js - angularjs 使用鼠标悬停时,标签一直闪2. c++ - win764位环境下,我用GCC为什么指针占8个字节,而long是4个字节?3. html5 - HTML代码中的文字乱码是怎么回事?4. 一个走错路的23岁傻小子的提问5. node.js - 函数getByName()中如何使得co执行完后才return6. java - 安卓电视盒子取得了root权限但是不能安装第三方应用,请问该怎么办?7. android - 安卓activity无法填充屏幕8. python 计算两个时间相差的分钟数,超过一天时计算不对9. javascript - SuperSlide.js火狐不兼容怎么回事呢10. python - django 里自定义的 login 方法,如何使用 login_required()
