Gio*_*rgi 5 javascript jquery jquery-plugins maskedinput jquery-events
我正在使用JQuery Masked输入插件.
$("#percent").mask("99.99?9");
Run Code Online (Sandbox Code Playgroud)
这允许数字 10.999, 10.99, 01.999, 01.99
我想要实现的是我不希望用户输入01.99.相反,如果用户键入1.99我想0前1自动添加.这是我开始但不知道如何继续:
//assume i typed in field 11.99
$(document).on('keyup', '#percent', function(evt) {
var input = $(this).val();
alert(input); // 11.99_
if(evt.which == '190' || evt.which == '110') {
//if dot is clicked
alert(parseInt(input)); // 11
}
});
Run Code Online (Sandbox Code Playgroud)
请注意,警报输入11.99_在末尾打印下划线,因为第三个值是可选的,我没有输入它.
现在,这个值是完全正常的,但如果用户输入的1.99,将不能因为它会自动移动9对1与填满它2的数字,所以它会作为回报19.9,这是无效的,因为必须有2定义如上小数.因此,在我的if语句中,我希望能够检测输入的内容是否小于10,如果小于10小数点,则0在开头添加.
好的,我发现了一个修复underscore _:
$("#percent").mask("99.99?9", {placeholder: ""})
Run Code Online (Sandbox Code Playgroud)
但仍然没有解决进入1.99存在的其他问题19.9
您可以拦截 keydown 来执行此操作,但您需要某种方法来刷新插件状态。
以下代码将起作用:
$("#percent").bind({
keydown: function(e) {
// custom handler for dot
var userInput = parseFloat($("#percent").val());
if(e.which == '190' || e.which == '110') {
// if entered number is integer and less than 10
if(userInput % 1 === 0 && userInput < 10) {
// prevent default mask input handlers from calling
e.preventDefault();
e.stopImmediatePropagation();
// update value
$("#percent").val('0'+userInput+'.');
// simulate paste event to refresh mask input plugin state
$("#percent").trigger('paste').trigger('input');
}
}
}
}).mask("99.99?9", {placeholder: ""});
Run Code Online (Sandbox Code Playgroud)
在这里工作 JSFiddle