10

我有一个非常简单的视图模型:

var ViewModel = function() {
    this.showRow = ko.observable(false);
    this.toggleVisibility = function() {
        if(this.showRow == true){
            this.showRow = false;
        }
        else{
            this.showRow = true;
        }
        alert('showRow is now '+this.showRow); //only here for testing
    };
};

使用同样简单的标记:

<a href="#" data-bind="click: toggleVisibility">Toggle</a>
<br />
<table>
    <tr data-bind="visible: showRow">Some Text</tr>
</table>

我的问题是,单击链接时,会显示警报框(显示正确的值-真/假)

但是,tr元素上的可见绑定似乎不起作用 - 无论是最初(该行在加载时应该是不可见的),还是在showRow切换的值时。

上面的jsFiddle- http://jsfiddle.net/alexjamesbrown/FgVxY/3/

4

1 回答 1

9

你需要修改你的html如下:

<table>
    <tr data-bind="visible: showRow"><td>Some Text</td></tr>
</table>

和JavaScript如下:

var ViewModel = function() {
    var self = this;
    self.showRow = ko.observable(false);
    self.toggleVisibility = function() {

        self.showRow(!self.showRow());
        alert('showRow is now ' + self.showRow());
    };
};

ko.applyBindings(new ViewModel());

将值设置为可观察属性的语法是:self.showRow(value);

如果需要在标签内有标签。

我还修改了您的小提琴以简化 javascript 并遵循关于“this”的更新代码实践。见http://jsfiddle.net/FgVxY/4/

于 2012-11-26T18:23:20.410 回答