angularjs 前端js正则表达式的运用

            网页当中总会有很多input的输入控件,需要填入日期格式、身份证格式、纯数字格式等等,这些如果放到后台校验会浪费很多时间,而且用户体验也不好,多出了一步操作,如果在js中,运用js的正则表达式来禁止用户输入对应的格式的话,会提升好大的体验,主要是使用onkeyup监听函数还有正则表达式:如下例子:

           (1)input输入框只能输入数字,长度为18,如果是字母或者中文,就要立即转换成空,以便进行校验,如下:

            (2)格式化成2010-01的字符串,如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="js/angular.min.js"></script>
<script src="js/jquery-1.10.1.min.js" type="text/javascript"></script>
</head>
<body>

<div ng-app="myApp" ng-model="myModel">

<!--  <p>名字 : <input step="0.01"   type="text" ng-model="name" maxlength="18" οnkeyup="value=value.replace(/[\u4E00-\u9FA5\uF900-\uFA2D]/,'')"></p>-->
  
  <p>日期格式化成2010-01,多余的部分进行切断 <input step="0.01"  id="ceshi" type="text" ng-model="test" maxlength="18"  οnkeyup="setTime(this.id);"></p>
  
  <p>只能输入数字,最大长度为18<input class="inp_txt" ng-blur="cardblur(card)" id="card" ng-maxlength="18" type="text" ng-model="card" name="card" placeholder="请输入身份证号码" required οnkeyup="value=value.replace(/[^\d]/g,'')" /></p>
  
</div>

<script>
	var app=angular.module('myApp',[]);
	app.controller('myModel',function ($scope) {
		$scope.name=110;
	});
	
	//只能输入数字,格式化成时间
	function setTime(id){
			var value = $("#" + id).val();
			value = value.replace(/[^0-9]*/g,"");
			var yearValue = value.substring(0,4);
			var monthValue = value.substring(4,6);
			if(value.length <= 6){
				if(yearValue != null && yearValue != ""){
					value = yearValue;
				}
				if(monthValue != null && monthValue != ""){
					value += "-" + monthValue;
				}
				$("#" + id).val(value);
			}else{
				$("#" + id).val(yearValue + "-" + monthValue);
			}
		}
	
</script>

</body>
</html>


    (3)input输入框,控制只能输入小数,中文自动清空: οnkeyup="value=value.replace(/[^\d(\.\d+)?]/g,'')"


参考:http://blog.sina.com.cn/s/blog_7256fe8f01017poa.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript正则表达式和Java正则表达式在语法上有一些差异,但是它们的基本概念和用法是相似的。下面是将JavaScript正则表达式转换为Java正则表达式的一些常见规则: 1. 语法差异: - JavaScript正则表达式使用斜杠(/)作为定界符,而Java正则表达式使用双引号(")作为定界符。 - JavaScript正则表达式中的特殊字符需要进行转义,而Java正则表达式中的特殊字符不需要转义。 2. 字符类: - JavaScript正则表达式中的字符类使用方括号([])表示,而Java正则表达式中使用方括号([])或者Unicode转义(\p{...})表示。 - JavaScript正则表达式中的字符类可以使用连字符(-)表示范围,而Java正则表达式中需要使用Unicode转义(\uXXXX)表示范围。 3. 量词: - JavaScript正则表达式中的量词使用花括号({})表示,而Java正则表达式中使用花括号({})或者问号(?)表示。 - JavaScript正则表达式中的贪婪量词默认是贪婪模式,而Java正则表达式中的贪婪量词需要在后面添加问号(?)来表示非贪婪模式。 4. 边界匹配: - JavaScript正则表达式中的边界匹配使用插入符号(^)和美元符号($)表示,而Java正则表达式中使用\A和\Z表示。 5. 其他差异: - JavaScript正则表达式中的捕获组使用圆括号(())表示,而Java正则表达式中使用圆括号(())或者方括号([])表示。 - JavaScript正则表达式中的反向引用使用反斜杠加数字(\1、\2等)表示,而Java正则表达式中使用美元符号加数字($1、$2等)表示。 以上是一些常见的JavaScript正则表达式转换为Java正则表达式的规则。具体转换时,还需要根据具体的正则表达式进行适当的调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值