我正在尝试使用jquery mask plugin对输入执行掩码,我需要做的是执行两个不同的掩码:
US###-###-###-###-###-### 如果用户首先尝试键入一些数字,则必须应用此掩码。(这里我的意思是用#输入数字)
但是如果用户一开始决定不输入任何数字,我想让他在此之后输入任何类型的字母或 unicod 字符或数字(完全任何字符)
我该怎么做这样的面具?
我正在尝试使用jquery mask plugin对输入执行掩码,我需要做的是执行两个不同的掩码:
US###-###-###-###-###-### 如果用户首先尝试键入一些数字,则必须应用此掩码。(这里我的意思是用#输入数字)
但是如果用户一开始决定不输入任何数字,我想让他在此之后输入任何类型的字母或 unicod 字符或数字(完全任何字符)
我该怎么做这样的面具?
一种可能的解决方案可能是使用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以查看工作示例。
希望它有用!