我正在使用淘汰赛邮箱来标记脏标志。代码如下所示:
var ProfileModel = function() {
this.nickName = ko.observable("name1").publishOn("dirty", true);
this.emailAddress = ko.observable("email1").publishOn("dirty", true);
};
ko.postbox.subscribe("dirty", function(newValue) {
// enable Save button
}, this);
nickName 和 emailAddress 绑定到输入框。
<div id="profile">
<input data-bind="value: nickName" /> </label>
<input data-bind="value: emailAddress" /></label>
</div>
重现问题的步骤:
- 用户到昵称输入框删除内容。
dirty
被提出并启用保存按钮。 - 用户单击保存按钮。更改已保存,并且“保存”按钮变为禁用。
- 用户转到 emailAddress 并删除内容。
dirty
不以某种方式提出。用户无法保存更改。 - 用户在 emailAddress 或 nickName 上键入内容。
dirty
被提出并启用保存按钮。
您可以查看jsfiddle以查看它的实际效果。jsfiddle示例中没有保存按钮,只是尝试删除nickName的内容,然后删除emailAddress。您将看到删除 emailAddress 不会引发dirty
事件。
这是淘汰邮箱中的已知错误吗?有没有更好的方法来检查淘汰赛的脏度?