7

例如:

在视图模型中,

//Makes webApi call to get the data from some repository
function GetData() {
            var data = http.get(apiUrl)
            .success(function (result) {
                 if (result != null || result !='')
                 {
                    // success display the data
                    vm.dataDisplay;
                 }
               else {
                    vm.errorMsg('No data');

                }
            })

//视图模型

 var vm = {
            activate: activate,
            dataDisplay: ko.observableArray(),
            errorMsg:ko.observable(''),
           };
        vm.activate();
        return vm;

//看法。预期的。

If( errorMsg == 'No Data')
{
// show errordata div and hides displayData div
<div class="errorData" data-bind="text:errorMsg"/>
}
else
{
// Show displayData div and hide errorData div
<div class="displayData" data-bind="text:dataDisplay" />
}

如何通过绑定来实现?

我可以使用 ko attr 或可见。但我的要求是仅通过绑定隐藏/显示。请建议我如何做到这一点?提前致谢。

4

2 回答 2

12

你是对的,你只需要使用visible绑定,它只会在 observable 的值不是 null、未定义或空字符串时显示 HTML 元素。这应该有效:

<div class="errorData" data-bind="visible: errorMsg, text:errorMsg"/>

<div class="displayData" data-bind="visible: dataDisplay, text:dataDisplay" />

此外,如果“dataDisplay”确实是一个数组,则必须使用:

<div class="displayData" data-bind="visible: dataDisplay().length, text:dataDisplay" />
于 2013-04-29T19:10:12.967 回答
0

使用此方法,因为它将帮助您解决您要实施的问题

self.ClickLoad=ko.observable(false);
self.Enable=ko.observable();
Enable=function(){
    self.ClickLoad=ko.observable(true);
    console.log(self.ClickLoad);
}

<div data-bind="visible: Enable()">
    <p>sjknscjksnajcn</p>
</div>
于 2016-10-24T11:59:39.010 回答