最近做用户注册登录时,需要监控用户的输入以此来给用户提示,用到了angular的$watch功能,以下是例子:
jsp:
<form class="register ng-scope" ng-app="regist_app" onsubmit="registSumbitValid()" ng-controller="regist_control"> <div class="item"> <input id="username" name="username" placeholder="请填写11位手机号码" class="input-item" ng-model="username" > <span class="warnning">{{username_error}}</span> </div> </form>
这里需要添加ng-app以及ng-controller来规定一个angularApp的范围,再在input标签中添加ng-model属性,让angularjs根据这个属性来监听输入,根据输入把用户提示放到{{username_error}}中
js:
var usernameValid=false; var registApp =angular.module('regist_app',[]); registApp.controller('regist_control',function($scope){ $scope.username=""; $scope.username_error=""; var phonePattern=/\D+/; /*验证号码输入*/ $scope.$watch('username',function(newValue,oldValue){ if(newValue!=oldValue){ if(newValue==""){ $scope.username_error="号码不能为空"; usernameValid=false; } else if(phonePattern.test(newValue)){ $scope.username_error='只能输入数字'; usernameValid=false; } else if(newValue.length!=11){ $scope.username_error='格式不正确,请输入11位号码'; usernameValid=false; }else if(newValue.length==11){ $scope.username_error=""; usernameValid=true; } } }); }
scope.scope.watch(参数,function),这个参数就是input的ng-model的值。function的第一个参数是新的值,第二个参数是旧的值,可以判断newValue来给用户相应的提示,结合pattern来判断用户输入是否合法。一个Controller中可以有多个scope.scope.watch(),这里我只贴出一个input的验证方法,其他的都差不多。
usernameValid这个值用来记录当前的input输入是否合法,用于表单提交时根据usernameValid来判断。
效果截图:
以上这篇angular实现input输入监听的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。