Knockout + customBinding不更新

时间:2012-03-01 07:01:05

标签: knockout.js

我有一个关于customBindings的快速问题,希望有些人可以帮我解释一下?我认为当更新observable时,任何绑定到该observable的customBinding都会调用其“update”方法。我可以看到,当我更新我的observable时,其他订阅者正在收到通知,但似乎没有调用customBinding。

这是我的viewModel:

var innerModel = {
    name: ko.observable('junk')
};

var innerModel2 = {
    name: ko.observable('junk2')
};

var viewModel = {
    im1: innerModel,
    im2: innerModel2,
    selectedModel: ko.observable({name:'xxx'})
};

这是我的customBinding:

ko.bindingHandlers.custom = {
    update: function(element, valueAccessor) {
        console.log("BAM!");
        while (element.firstChild)
            ko.removeNode(element.firstChild);

        ko.renderTemplate('test', valueAccessor(), {}, element, 'replaceNode');

    }  
};

其中我的模板只是一个显示“名称”字段的范围:

<script id='test' type='text/html' charset='utf-8'>
<span data-bind='text: name'></span>
</script>

以下是我与customBinding一起使用的HTML:

<div id="container" data-bind="with: viewModel">
    <div data-bind="custom: selectedModel">
    </div>
</div>

当我将selectedModel更新为两个innerModel中的任何一个时,会显示正确的名称,但不会调用customBinding的'update'函数。我有一个单独的订阅者“selectedModel”observable:

viewModel.selectedModel.subscribe(function(newValue) {
    console.log(newValue.name());
});

当我更改selectedModel时会调用它,那么为什么不调用customBinding的更新?

这是一个显示问题的jsfiddle: http://jsfiddle.net/gperng/twAcJ/

任何帮助将不胜感激!

2 个答案:

答案 0 :(得分:9)

您需要调用以下函数才能使其正常工作:

var valueUnwrapped = ko.utils.unwrapObservable(valueAccessor())

试试这个小提琴:http://jsfiddle.net/twAcJ/13/

答案 1 :(得分:0)

在这种情况下,您使用with是错误的。如果您使用它,它将按预期工作:

<div id="container" data-bind="with: selectedModel">
    <div data-bind="custom: $data">
    </div>
</div>

这是因为在您的示例中,custom绑定不在selectedModel上,而是在整个viewModel本身上不会发生变化。

以下是jsfiddle:http://jsfiddle.net/soniiic/twAcJ/7/