繁体   English   中英

当儿童可观察者更新时,淘汰赛js css似乎没有重新计算

[英]Knockout js css doesn't seem to recalculate when child observable is updated

我对Knockout相当陌生,想尽一切办法观察可观察物和计算可观察物。

更新:JS Fiddle: http : //jsfiddle.net/tQ576/4/带有运行但损坏的示例。 在输入框中输入内容后,标签的标签应变为绿色。

我有一个这样的模型:

var json = {
    name: 'Testing',
    items: [{
        question: 'Question 1',
        answer: '',
        isrequired: true,
        isvisible: true,
        complexObject: {
            FirstName: '',
            LastName: '',
            Email: ''
        }
    }, {
        question: 'Question 2',
        answer: '',
        isrequired: true,
        isvisible: true,
        complexObject: {
            FirstName: '',
            LastName: '',
            Email: ''
        }
    }]
};

var ViewModel = function () {
    var self = this;
    self.profile = ko.observable(new Profile(json));
};

var Profile = function (init) {
    var self = this;
    self.name = ko.observable(init.name);
    self.items = ko.observableArray([]);
    for (var i = 0; i < init.items.length; i++) {
        self.items.push(new ProfileItem(init.items[i]));
    }
};

var ComplexObject = function () {
    var self = this;
    self.name = ko.observable("");
    self.email = ko.observable("");
}

var ProfileItem = function (item) {
    var self = this;
    self.question = ko.observable(item.question);
    self.answer = ko.observable(item.answer);
    self.complexObject = ko.observable(new ComplexObject());
    self.isvisible = ko.observable(item.isvisible);
    self.isrequired = item.isrequired;
    self.cssclasses = ko.computed(function () {
        if (self.complexObject().Email != undefined && self.complexObject().Email().length > 0) {
            return "satisfied";
        } else {
            return "required";
        }
    });
};

ko.applyBindings(new ViewModel());

然后在我的html中,我有这样的模板:

<div data-bind="foreach: profile().items">
    <div data-bind="css: cssclasses">
        <span data-bind="text: question"></span><br />
        <div data-bind="with: complexObject">
            <input data-bind="value: email" />
        </div>
    </div>
</div>
<div data-bind="text: ko.toJSON($root)"></div>

似乎当为“电子邮件”更新值时,cssclasses计算的值永远不会重新计算。 有没有办法强制这种重新计算?

最好的问候,并感谢大家的帮助。

JS小提琴: http//jsfiddle.net/tQ576/4/

哈尔

如果您在计算的email中取消大写,则可以使用。 小提琴

self.complexObject().Email !== undefined && self.complexObject().Email().length > 0)更改为self.complexObject().email !== undefined && self.complexObject().email().length > 0) -因为这就是您在视图模型和数据绑定中使用它的方式。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM