工作当中用到的:有是,用户会在文本框里输入一些无效的(错误的)内容,比如在手机号中输入#等等,一般使用正则表达式,但是只有点击的时候才会验证,用户体验不好,所以想屏蔽这些按键,让键盘根本打不出来,以下是代码(不是完全原创,参考了网上的一些例子)
代码:
1 input.keydown(function (evt) {
2 evt.stopPropagation();
3 if (
4 // Allow: backspace, delete, tab, escape, enter and .
5 $.inArray(evt.keyCode, [46, 8, 9, 27]) !== -1 ||
6 // Allow: Ctrl+A
7 (evt.keyCode === 65 && evt.ctrlKey === true) ||
8 // Allow: home, end, left, right
9 (evt.keyCode >= 35 && evt.keyCode <= 39)) {
10 // let it happen, don't do anything
11 return;
12 } else if (evt.shiftKey || (evt.keyCode < 48 || evt.keyCode > 57) && (evt.keyCode < 96 || evt.keyCode > 105)) {
13 if (evt.keyCode == 13) {
14 if (/^[0-9]*[1-9][0-9]*$/.exec(input.val()) && parseInt(input.val()) <= parseInt(pageCountEle.val())) {
15 pageNoEle.val(input.val());
16 jsMethodName();
17 } else {
18 alert("Please input a valid number!");
19 input.focus();
20 return false;
21 }
22 }
23 evt.preventDefault();
24 }
25 });