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

前端之家收集整理的这篇文章主要介绍了angularjs 前端js正则表达式的运用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <Meta charset="utf-8">
  5. <script src="js/angular.min.js"></script>
  6. <script src="js/jquery-1.10.1.min.js" type="text/javascript"></script>
  7. </head>
  8. <body>
  9.  
  10. <div ng-app="myApp" ng-model="myModel">
  11.  
  12. <!-- <p>名字 : <input step="0.01" type="text" ng-model="name" maxlength="18" onkeyup="value=value.replace(/[\u4E00-\u9FA5\uF900-\uFA2D]/,'')"></p>-->
  13. <p>日期格式化成2010-01,多余的部分进行切断 <input step="0.01" id="ceshi" type="text" ng-model="test" maxlength="18" onkeyup="setTime(this.id);"></p>
  14. <p>只能输入数字,最大长度为18<input class="inp_txt" ng-blur="cardblur(card)" id="card" ng-maxlength="18" type="text" ng-model="card" name="card" placeholder="请输入身份证号码" required onkeyup="value=value.replace(/[^\d]/g,'')" /></p>
  15. </div>
  16.  
  17. <script>
  18. var app=angular.module('myApp',[]);
  19. app.controller('myModel',function ($scope) {
  20. $scope.name=110;
  21. });
  22. //只能输入数字,格式化成时间
  23. function setTime(id){
  24. var value = $("#" + id).val();
  25. value = value.replace(/[^0-9]*/g,"");
  26. var yearValue = value.substring(0,4);
  27. var monthValue = value.substring(4,6);
  28. if(value.length <= 6){
  29. if(yearValue != null && yearValue != ""){
  30. value = yearValue;
  31. }
  32. if(monthValue != null && monthValue != ""){
  33. value += "-" + monthValue;
  34. }
  35. $("#" + id).val(value);
  36. }else{
  37. $("#" + id).val(yearValue + "-" + monthValue);
  38. }
  39. }
  40. </script>
  41.  
  42. </body>
  43. </html>


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


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

猜你在找的Angularjs相关文章