6

我在可观察数组上使用 foreach:

<div id="mainRight" data-bind="foreach: notifications">
    <div class="statusRow">
        <div class="leftStatusCell">
            <div class="leftStatusCellColor" data-bind="css: availabilityCssClass($data.availability)"></div>
        </div>
        <div class="topRightStatusCell" data-bind="text: sip"></div>
        <div class="bottomtRightStatusCell ellipsisSingleline" data-bind="text: note"></div>
    </div>
</div> <!== end mainRight ==>

如您所见,我将可用性的当前值传递给函数availabilityCssClass,该函数将该值与一些预定义的字符串进行比较。根据匹配的字符串,它返回一个类名。

self.availabilityCssClass = ko.computed(function (value) {
    var availability = value;
    if (availability === "Busy" || "DoNotDisturb" || "BeRightBack")
        return "leftStatusCellColorOrange";
    else if (availability === "Away" || "Offline")
        return "leftStatusCellColorRed";
    else
        return "leftStatusCellColorGreen";
});

这是我的模型。数据来自外部数据源。

function Notification(root, sip, availability, note) {
    var self = this;

    self.sip = ko.observable(sip);
    self.availability = ko.observable(availability);
    self.note = ko.observable(note);
};

self.notifications = ko.observableArray();

但是,它不能按原样工作。当计算函数没有被注释掉时,foreach 不会遍历数据并且 div 为空。但我可以看到 viewModel 不是空的。

4

3 回答 3

4

您不能以这种方式将值传递给计算。最好将此计算结果添加到Notification视图模型并使用self.availability属性:

function Notification(root, sip, availability, note) {
    var self = this;

    self.sip = ko.observable(sip);
    self.availability = ko.observable(availability);
    self.note = ko.observable(note);

    self.availabilityCssClass = ko.computed(function() {
        var availability = self.availability();

        if (["Busy", "DoNotDisturb", "BeRightBack"].indexOf(availability) != -1) return "leftStatusCellColorOrange";
        else if (["Away", "Offline"].indexOf(availability) != -1) return "leftStatusCellColorRed";
        else return "leftStatusCellColorGreen";
    });
};

你的if说法不正确,所以我修正了逻辑。这是工作小提琴:http: //jsfiddle.net/vyshniakov/Jk7Fd/

于 2012-11-19T12:17:35.017 回答
1

你只需要创建availabilityCssClass一个函数。正如您所写,它不是计算的可观察对象,因为它没有可观察的依赖项。

self.availabilityCssClass = function (value) {
    var availability = value;
    if (availability === "Busy" || "DoNotDisturb" || "BeRightBack")
        return "leftStatusCellColorOrange";
    else if (availability === "Away" || "Offline")
        return "leftStatusCellColorRed";
    else
        return "leftStatusCellColorGreen";
};
于 2012-11-19T21:08:43.530 回答
0

CSS 绑定需要一个对象字面量,其中 CSS 类的名称作为成员名称,值 true 或 false 取决于您要删除或添加类

data-bind="css: { 'css-class-name': true }"

编辑:嗯,他们在 2.2 中更改了 css 绑定;)

于 2012-11-19T12:17:59.723 回答