5

我正在使用 JQuery Masked 输入插件。

$("#percent").mask("99.99?9");

这允许像10.999, 10.99, 01.999, 01.99

我想要实现的是我不希望用户键入01.99. 相反,如果1.990之前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
    }
});

请注意,11.99_由于第三个值是可选的并且我没有输入,因此警报输入在末尾带有下划线打印。

现在这个值是完全正常的,但是如果用户输入1.99, 将不能,因为它会自动移动912数字填充它,所以它会返回 as19.9并且这是无效的,因为必须有2上面定义的小数。因此,在我的 if 语句中,我希望能够检测输入的内容是否小于10,如果小于10小数点,则0在开头添加。

好的,我找到了解决方法underscore _

    $("#percent").mask("99.99?9", {placeholder: ""})

1.99但仍然没有解决其他问题19.9

4

1 回答 1

0

您可以拦截 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: ""});

在这里工作 JSFiddle

于 2012-11-18T08:19:30.100 回答