首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >正则表达式输入掩码的角度?

正则表达式输入掩码的角度?
EN

Stack Overflow用户
提问于 2015-02-03 04:57:02
回答 2查看 8.3K关注 0票数 9

‘`Angular Utils’项目(link)中的ui-mask有点太有限了。

例如,美国电话号码的第一个数字应该是2-9。在ngPattern中,它应该是

代码语言:javascript
运行
复制
ng-pattern="/^\([2-9]\d{2}\)\d{3}-\d{4}(x\d{1,4})?$/"

那么,如何编写一个输入掩码来防止用户在第一个数字中输入0或1?有没有更好的输入掩码我们应该用在Angular上?

EN

回答 2

Stack Overflow用户

发布于 2015-04-25 13:17:30

我想你可以在这里找到答案:https://github.com/angular-ui/ui-utils/issues/16

正如链接中所解释的,您可以从作用域/控制器变量获取掩码,检查输入并根据需要更改掩码,如下所示:

代码语言:javascript
运行
复制
<input type="text" ui-mask="{{mask}}" ng-keyup="onKeyUp()" ng-model="myinput">


$scope.myinput = '';
var defaultMask  = '(99) 9999-9999';
$scope.mask = defaultMask;
$scope.onKeyUp = function(){
  if ($scope.myinput.slice(0,3) == '119') { // (11) 9 means mobile, or instead, you could use a regex
    $scope.mask = '(99) 99999-9999';
  } else {
    $scope.mask = defaultMask;
  }
};
票数 4
EN

Stack Overflow用户

发布于 2015-05-06 19:45:32

允许基于AngularJS的正则表达式模式的某些输入

http://alphagit.github.io/ng-pattern-restrict/

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28286588

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档