KnockoutJS - 过滤用户输入

时间:2012-05-02 07:08:35

标签: javascript knockout.js

我有一个简单的输入文本元素:

<input type="text" data-bind="value:valInserted,valueUpdate:'afterkeydown'" />

如何验证此元素的用户输入?我有一个问题,即创建适当的绑定来移植jQuery代码:

$('[id$="pinBox"] :text').keypress(function (e)
{
   if (!(e.charCode >= 48 && e.charCode <= 57) && e.keyCode != 8)
   {
       return false;
   }
});

1 个答案:

答案 0 :(得分:0)

我想我终于明白了。

<input type="text" data-bind="validateValue:valInserted,valueUpdate:'afterkeydown',value:valInserted" />

ko.bindingHandlers.validateValue = {
    update: function (element, valueAccessor, allBindingsAccessor, viewModel)
    {
        var value = ko.utils.unwrapObservable(valueAccessor());
        viewModel.valInserted(value.replace(/[^0-9]/g, ''));
    }
};