2

似乎淘汰验证插件以某种方式阻止执行点击处理程序。这是我的简化代码。

HTML:

<div>
    <input type="text" data-bind="value: code" />
    <button data-bind="click: execute">VALIDATE</button>
</div

Javascript:

<script type="text/javascript" language="javascript">
    $(document).ready(function () {
        var ViewModel = function () {
            var self = this;
            this.code = ko.observable();
            this.code.extend({ required: true });
            this.execute = function () {
                if (self.code.isValid()) {
                    alert("SUCCEED");
                }
                else {
                    self.code.valueHasMutated(); //just to show error message
                    alert("FAILED");
                }
            };
        };

        ko.applyBindings(new ViewModel());
    });
</script>

我的场景:

  1. 加载页面
  2. 单击 VALIDATE - 出现错误消息并且警报显示 FAILED
  3. 在输入中输入任何文本并立即单击验证 - 错误消息消失,但没有显示警报。
  4. 再次单击 VALIDATE - 只有现在可以看到带有 SUCCEED 文本的警报。

如何解决此问题,以便验证按钮从第一次单击时就可以正常工作?

谢谢, 伊霍尔

4

2 回答 2

2

3)你从不点击按钮:D

发生的情况是,当您从该字段失去焦点时,它会验证该字段并删除文本,从而使按钮更改位置并且您的点击错过了按钮

http://jsfiddle.net/s2bbd/

这个工作就像你怀疑 http://jsfiddle.net/s2bbd/1/

Stackoverflow wont let me post this without code
于 2012-11-30T15:03:17.570 回答
0

单击前验证的另一种方法是使用鼠标悬停来模糊当前元素。

<button data-bind="click: execute" onmouseover="document.activeElement.blur();">VALIDATE</button>
于 2015-04-09T13:03:40.007 回答