我有一个 input type="number",其中最小值为 1,最大值为 10。我想防止输入大于或小于最大值和最小值的值,因此我使用此脚本:
$('input[name=inputModal1]').keyup(function(){
if($(this).val()>10){
$(this).val(10);
}else if($(this).val()<1){
$(this).val(1);}
});
$('input[name=inputModal2]').keydown(function(){
if($(this).val()>10){
$(this).val(10);
}else if($(this).val()<1){
$(this).val(1);}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="number" name="inputModal1" min="1" max="10" value="1">
<input type="number" name="inputModal2" min="1" max="10" value="1">
在这种脚本中,脚本可以工作,但我想使用 keydown
,它可以防止输入多于或少于最大值和最小值,但是 keyup
会在用户按下和按住按钮。 keydown
不起作用的原因可能是什么?我可以删除该值,使其大于 10,等等。
如果您需要更多信息,请告诉我。
答案 0 :(得分:4)
问题与事件的顺序有关。 keydown
在元素设置之前触发。因此,当事件触发时 $(this).val()
是 ''
,这会混淆您的逻辑。
要解决此问题并改进行为,请改用 input
事件。这可以根据您的需要工作,并且也会在用户以任何方式向元素添加内容时触发 - 例如通过鼠标粘贴。
此外,您可以使用 Math.min()
和 Math.max()
使您的逻辑更加简洁。试试这个:
$('input[name=inputModal]').on('input', function() {
$(this).val((i, v) => Math.max(Math.min(this.value, 10), 0));
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<input type="number" name="inputModal" min="1" max="10">