0

我正在使用淘汰赛邮箱来标记脏标志。代码如下所示:

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>

重现问题的步骤:

  1. 用户到昵称输入框删除内容。dirty被提出并启用保存按钮。
  2. 用户单击保存按钮。更改已保存,并且“保存”按钮变为禁用。
  3. 用户转到 emailAddress 并删除内容。dirty不以某种方式提出。用户无法保存更改。
  4. 用户在 emailAddress 或 nickName 上键入内容。dirty被提出并启用保存按钮。

您可以查看jsfiddle以查看它的实际效果。jsfiddle示例中没有保存按钮,只是尝试删除nickName的内容,然后删除emailAddress。您将看到删除 emailAddress 不会引发dirty事件。

这是淘汰邮箱中的已知错误吗?有没有更好的方法来检查淘汰赛的脏度?

4

1 回答 1

1

默认情况下, 的publishOn功能knockout-postbox不会再次发布最新值。在您的示例中,您正在为“dirty”(空昵称)发布一个空字符串,然后再次发布一个空字符串(空电子邮件)。

publishOn确实支持传入您自己的相等比较器。在您的情况下,您可以传入一个始终返回的函数false

例如,类似:

var alwaysPublish = function() { return false; }

var ProfileModel = function() {
    this.nickName = ko.observable("Ryan").publishOn("dirty", true, alwaysPublish);
    this.emailAddress = ko.observable("ryan@knockmeout.net").publishOn("dirty", true, alwaysPublish);
    this.log = ko.observableArray();
};

这是一个小提琴:http: //jsfiddle.net/rniemeyer/qmbwhk8a/

您还可以通过设置全局覆盖比较功能ko.postbox.defaultComparer

于 2015-02-03T02:49:38.603 回答