событие onchange для типа ввода = «число»

86

Как я могу справиться с заменой <input type="number" id="n" value="5" step=".5" />? Я не могу сделать keyupили keydown, потому что пользователь может просто использовать стрелки для изменения значения. Я бы хотел обрабатывать его всякий раз, когда он изменяется, а не только при размытии, как я думаю, .change()событие. Есть идеи?

Ян Дэвис
источник
2
Вы понимаете, что тип ввода не поддерживается IE или Firefox?
AlienWebguy,
Теперь он поддерживается Firefox
ElephantHunter
2
caniuse.com/#feat=input-number Да, я комментирую вопрос шестилетней давности.
Пит

Ответы:

135

Используйте mouseup и keyup

$(":input").bind('keyup mouseup', function () {
    alert("changed");            
});

http://jsfiddle.net/XezmB/2/

Джон Колвин
источник
4
Это будет предупреждать, даже если значение не изменилось (просто щелкните в любом месте input).
Джеймс Аллардис,
Да, это будет. Если это проблема, вы должны отслеживать значение на входе в глобальной переменной или в элементе данных на входе. Когда событие mouseup вызывает вашу функцию, сравните это значение с текущим значением ввода. Делайте что-нибудь, только если значение изменилось.
JohnColvin 08
3
Это не работает, если значение изменяется с помощью прокрутки мыши над элементом.
Ондрей Мачулда
7
Добавьте событие «колесо мыши» для поддержки изменений с помощью прокрутки.
Martijn
4
Если пользователь удерживает клавишу со стрелкой, чтобы изменить значение, то это не срабатывает, пока клавиша со стрелкой не будет отпущена. Использование inputвместо этого (как предлагается в другом ответе), кажется, работает лучше.
Джош Келли
76

oninputСобытие ( .bind('input', fn)) охватывает любые изменения от нажатий клавиш со стрелкой щелчки и клавиатуры / мыши пасты, но не поддерживается в IE <9.

jQuery(function($) {
  $('#mirror').text($('#alice').val());

  $('#alice').on('input', function() {
    $('#mirror').text($('#alice').val());
  });
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<input id="alice" type="number" step="any" value="99">

<p id="mirror"></p>

Фло
источник
10

http://jsfiddle.net/XezmB/8/

$(":input").bind('keyup change click', function (e) {
    if (! $(this).data("previousValue") || 
           $(this).data("previousValue") != $(this).val()
       )
   {
        console.log("changed");           
        $(this).data("previousValue", $(this).val());
   }

});


$(":input").each(function () {
    $(this).data("previousValue", $(this).val());
});​

Это немного гетто, но таким образом вы можете использовать событие «щелчок» для захвата события, которое запускается, когда вы используете мышь для увеличения / уменьшения с помощью маленьких стрелок на входе. Вы можете видеть, как я встроил небольшую ручную процедуру «проверки изменений», которая гарантирует, что ваша логика не сработает, если значение действительно не изменится (для предотвращения ложных срабатываний от простых щелчков по полю).

Джейк Физел
источник
6

Чтобы определить, когда нажата мышь или клавиша, вы также можете написать:

$(document).on('keyup mouseup', '#your-id', function() {                                                                                                                     
  console.log('changed');
});
Кингсли Иджома
источник
3
$(':input').bind('click keyup', function(){
    // do stuff
});

Демо: http://jsfiddle.net/X8cV3/

AlienWebguy
источник
Это все равно будет выполнено, если значение не изменилось (просто щелкните в любом месте input).
Джеймс Аллардис,
Это правда, но как только он фиксирует событие, он может определить, изменилось ли значение или нет.
AlienWebguy,
3

Поскольку $("input[type='number']")это не работает в IE, мы должны использовать имя или идентификатор класса, например $('.input_quantity').

И не используйте .bind()метод. Этот .on()метод является предпочтительным методом прикрепления обработчиков событий к документу.

Итак, моя версия:

HTML

<input type="number" value="5" step=".5" min="1" max="999" id="txt_quantity" name="txt_quantity" class="input_quantity">

jQuery

<script>
$(document).ready(function(){
    $('.input_quantity').on('change keyup', function() {
        console.log('nice');
    }); 
});
</script>
SandroMarques
источник
1

Возможно, есть лучшее решение, но вот что пришло в голову:

var value = $("#yourInput").val();
$("#yourInput").on('keyup change click', function () {
    if(this.value !== value) {
        value = this.value;
        //Do stuff
    }        
});

Вот рабочий пример .

Он просто связывает обработчик событий с событиями keyup, changeи click. Он проверяет, изменилось ли значение, и, если да, сохраняет текущее значение, чтобы можно было проверить его снова в следующий раз. Чек необходим для работы с clickсобытием.

Джеймс Аллардис
источник
Загромождение глобальной области видимости переменной с именем valueвызывает проблемы.
AlienWebguy,
Совершенно верно. Как и ваш ответ, это всего лишь пример. Я думаю, что у @JakeFeasel, вероятно, самое чистое решение.
Джеймс Аллардис,
1
$("input[type='number']").bind("focus", function() {
    var value = $(this).val();
    $(this).bind("blur", function() {
        if(value != $(this).val()) {
            alert("Value changed");
        }
        $(this).unbind("blur");
    });
});

ИЛИ ЖЕ

$("input[type='number']").bind("input", function() {
    alert("Value changed");
});
NK
источник
1
<input type="number" id="n" value="0" step=".5" />
<input type="hidden" id="v" value = "0"/>

<script>
$("#n").bind('keyup mouseup', function () {
    var current = $("#n").val();
    var prevData = $("#v").val(); 
    if(current > prevData || current < prevData){
       $("#v").val(current);
       var newv = $("#v").val(); 
       alert(newv);
    } 
});  
</script>

http://jsfiddle.net/patrickrobles53/s10wLjL3/

Я использовал скрытый тип ввода как контейнер предыдущего значения, которое потребуется для сравнения при следующем изменении.

Патрик Роблес
источник
вы можете использовать только data-prevатрибут для хранения предыдущего значения. Не нужно использовать дополнительный ввод
shukshin.ivan
1

У меня была такая же проблема, и я решил использовать этот код

HTML

<span id="current"></span><br>
<input type="number" id="n" value="5" step=".5" />

Вы можете добавить только 3 первые строки, остальные части необязательны.

$('#n').on('change paste', function () {
    $("#current").html($(this).val())   
});
// here when click on spinner to change value, call trigger change
$(".input-group-btn-vertical").click(function () {
   $("#n").trigger("change");
});
// you can use this to block characters non numeric
$("#n").keydown(function (e) {
    // Allow: backspace, delete, tab, escape, enter and .
    if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 110, 190]) !== -1 || (e.keyCode === 65 && e.ctrlKey === true) || (e.keyCode >= 35 && e.keyCode <= 40)) 
           return;

    if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) 
       e.preventDefault();
});

Пример здесь: http://jsfiddle.net/XezmB/1303/

Бруно Рибейро
источник