AngularJS表单验证【失去焦点再提示】

 

    使用angular自带的表单验证时,页面加载的时候就显示出来了,用户体验不太好,我们的需求是,只有当输入框失去了焦点的时候才显示提示内容

   解决办法:利用了angularjs表单验证的错误对象 myForm.input.$error,给这个对象添加一个判断当前输入框是否失去焦点的属性 myForm.input.$error.blur。然后利用input的事件ng-focus,ng-blur来动态改变这个值。

注意:因为一开始 myForm.input.$error.blur 没有给定初始值,所以肯定是false

<html>
	<head>
		<title></title>
        <--引用自己的js-->
		<script src="js/angular.min.js" type="text/javascript" charset="utf-8"></script>
		<script type="text/javascript">
			angular.module('app', [])
		</script>
	</head>

	<body ng-app="app">
		<form name="myForm" >
			<div class="">
				用户名
				<input name="input" ng-model="userType" ng-blur="myForm.input.$error.focus=false" ng-focus="myForm.input.$error.focus=true" required>
				<span ng-show="myForm.input.$error.required && !myForm.input.$error.focus">必填项</span><br>
			</div>
			<div class="">
				密码:
				<input name="psd" ng-model="psd" ng-blur="myForm.psd.$error.blur=true" ng-focus="myForm.psd.$error.blur=false" required>
				<span ng-show="myForm.psd.$error.required &&myForm.psd.$error.blur">必填项</span><br>
			</div>
		</form>
	</body>
</html>

 

转载于:https://my.oschina.net/u/3060934/blog/877558

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值