3

我正在尝试使用jquery mask plugin对输入执行掩码,我需要做的是执行两个不同的掩码:

US###-###-###-###-###-### 如果用户首先尝试键入一些数字,则必须应用此掩码。(这里我的意思是用#输入数字)

但是如果用户一开始决定不输入任何数字,我想让他在此之后输入任何类型的字母或 unicod 字符或数字(完全任何字符)

我该怎么做这样的面具?

4

1 回答 1

2

一种可能的解决方案可能是使用jQuery Mask Plugin 的文档中调用的On-the-fly mask change内容,如下所示:

HTML

<input type="text" class="US" maxlength="20" autocomplete="off"/>

jQuery :

$(document).ready(function(){
    var options =  {onKeyPress: function(us){
        var masks = ['CAAAA-AAA-AAA-AAA-AAA-AAA', 'US000-000-000-000-000-000'];
        if(us.length){
            mask = (us[0].match(/\d/)) ? masks[1] : masks[0];
            $('.US').mask(mask, this);
        }
        $('.US').mask('AAAAA-AAA-AAA-AAA-AAA-AAA', this);
    }};

    $('.US').mask('AAAAA-AAA-AAA-AAA-AAA-AAA', options);
});

说明

您输入的问题是它使用了字符 S。尽管 S 在插件中已经具有不同的含义。根据默认掩码图例:

S: Only A-Z and a-z characters.

所以你有两个选项来解决这个问题:使用翻译模式,或者覆盖“jquery.mask.js”中的默认选项:

var custom_options = {
  byPassKeys: [8, 9, 37, 38, 39, 40],
  translation: {
                '0': {pattern: /\d/}, 
                '9': {pattern: /\d/, optional: true}, 
                '#': {pattern: /\d/, recursive: true}, 
                'A': {pattern: /[a-zA-Z0-9]/}, 
                'S': {pattern: /[a-zA-Z]/}
            };
};

我选第二个!我将“S”更改为“C”。可能是另一个角色。

检查此链接jsfiddle以查看工作示例。

希望它有用!

于 2014-10-06T13:43:32.097 回答