1

看看这个小提琴:http: //jsfiddle.net/XuMzS/4/

html:

<input data-bind="value: Total" type="text" />
<textarea cols="50" rows="10" data-bind="value: testHtml, valueUpdate: 'afterkeydown'">
</textarea>
<p>Html:</p>
<div class="wrapper">
<div data-bind="html: testHtml"></div>
<br />
</div>

javascript:

function viewModel() {
var self = this;
self.Total = ko.observable("1337");
self.testHtml = ko.observable();

}

ko.applyBindings(new viewModel());

我想要做的是通过在文本区域内编写所需的代码来显示可观察的总计(在它下面的 div 中显示 html)。就像我写的:

<span data-bind="text: Total"></span>

但是,如果我编写该代码,则不会显示任何内容。否则正常的 html 正在工作。有什么方法可以做到这一点吗?

4

2 回答 2

2

我做了一个样品,我想这就是你要找的。

function viewModel() {
    var self = this;
    self.Total = ko.observable("1337");
    self.testHtml = ko.observable("<b>test</b><span data-bind=\"text: Total\"></span>");
    self.testHtmlWrapper = ko.computed(function () {
        return '<div id="dynamicContent">' + self.testHtml() + '</div>';
    });

    self.rebind = function () {
        try {
            ko.applyBindings(self, document.getElementById("dynamicContent"));
        } catch (e) {

        }
    };
    self.testHtml.subscribe(self.rebind);

}

var vm = new viewModel();
ko.applyBindings(vm);
vm.rebind();

见小提琴

我希望它有所帮助。

于 2013-05-24T15:23:32.117 回答
0

为什么需要 testHtml 可观察对象?

这可以使用下面的代码轻松完成。

视图模型:

function viewModel() {
    var self = this;
    self.Total = ko.observable("1337");
}

ko.applyBindings(new viewModel());

html:

<input data-bind="value: Total" type="text" />
<textarea cols="50" rows="10" data-bind="valueUpdate: 'afterkeydown'">
<b>test</b><span data-bind="text: Total"></span>
</textarea>
<p>Html:</p>
<div class="wrapper">
    <div><b>test</b><span data-bind="text: Total"></span></div>
    <br />
</div>

看到这个小提琴

于 2013-05-27T05:12:05.713 回答