Я хотел использовать эту технику: сделать ввод только числовым типом при нокауте
чтобы пользователь мог вводить только числа.
Однако этот метод не обновляет наблюдаемое значение в пользовательском интерфейсе.
HTML:
<span data-bind="text: Interval" ></span>
<input data-bind="numeric: Interval" />
Переплет:
ko.bindingHandlers.numeric = {
init: function (element, valueAccessor) {
$(element).on("keydown", function (event) {
// Allow: backspace, delete, tab, escape, and enter
if (event.keyCode == 46 || event.keyCode == 8 || event.keyCode == 9 || event.keyCode == 27 || event.keyCode == 13 ||
// Allow: Ctrl+A
(event.keyCode == 65 && event.ctrlKey === true) ||
// Allow: . ,
(event.keyCode == 188 || event.keyCode == 190 || event.keyCode == 110) ||
// Allow: home, end, left, right
(event.keyCode >= 35 && event.keyCode <= 39)) {
// let it happen, don't do anything
return;
}
else {
// Ensure that it is a number and stop the keypress
if (event.shiftKey || (event.keyCode < 48 || event.keyCode > 57) && (event.keyCode < 96 || event.keyCode > 105)) {
event.preventDefault();
}
}
});
}
};
Таким образом, привязка не позволяет вводить символы, отличные от цифр, но когда фокус теряется на input
, соответствующий наблюдаемый не обновляется (поэтому элементы span
не изменяются).
Примечание:
Мне не нужно позволять пользователю вводить нечетные символы на вход. Я знаю, что есть другое решение, такое как числовое расширение ko, которое преобразует все в числовые числа, но мне это не нужно. Мне нужно решение, которое позволяет вводить только цифры (включая что-то вроде backspace и т.д.).