【发布时间】:2016-01-19 23:06:13
【问题描述】:
我试图让用户只输入数字并将控件复制并粘贴到文本框中。我可以限制用户仅输入数字,但复制、粘贴对我不起作用帮助我解决此问题。
这是我的脚本:
$(".allow_only_numbers").keydown(function (e) {
var ctrlDown = false;
var ctrlKey = 17, vKey = 86, cKey = 67;
if (e.keyCode === ctrlKey){
ctrlDown = true;
}
// Allow: backspace, delete, tab, escape, enter and .
if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 110]) !== -1 ||
// Allow: Ctrl
(e.keyCode === ctrlKey) ||
// Allow: Ctrl+A
(e.keyCode === 65 && e.ctrlKey === true) ||
// Allow: Ctrl+v
(e.keyCode === vKey && ctrlDown) ||
// Allow: Ctrl+c
(e.keyCode === cKey && ctrlDown) ||
// Allow: home, end, left, right, down, up
(e.keyCode >= 35 && e.keyCode <= 40)) {
// let it happen, don't do anything
return;
}
// Ensure that it is a number and stop the keypress
if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
e.preventDefault();
}
});
这里是 jsfiddle 链接:
https://jsfiddle.net/sureshpattu/stwzhceL/1/
【问题讨论】:
-
你不能只将类型设置为数字吗?
<input type="number" name="quantity" min="1" max="5">? -
@Pekka 我可以限制用户只输入数字,但复制、粘贴对我不起作用。
-
对于现代浏览器可以使用
input事件进行粘贴和按键事件。 IE9 部分支持,IE8 不支持 -
@SureshPattu 你试过我的答案了吗?
-
@JohnR 是的,我试过了,非常感谢 :)
标签: javascript jquery regex keycode