0

我在页面上显示了一个步骤列表。一些步骤(但不是全部)将有 1-3 个子步骤。我在想最简单的方法是在视图模型的每个步骤声明中手动编写 HTML。

如果您查看下面的代码,我想做的是:

this.sidebarStepModel1 = new SidebarStepModel();
this.sidebarStepModel1.message("step 2 <ul><li>substep 1</li><li>substep2</li></ul>");

问题是,在那里编写的 HTML 被解释为 astring而不是HTML. 我怎样才能使它将 HTML 解释为实际的 HTML?

小提琴:https ://jsfiddle.net/8o31m6rq/2/

HTML:

<ul>
    <sidebar-step params="vm: sidebarStepModel0"></sidebar-step>
    <sidebar-step params="vm: sidebarStepModel1"></sidebar-step>
    <sidebar-step params="vm: sidebarStepModel2"></sidebar-step>
</ul>

JavaScript/淘汰赛:

//custom element <sidebar-step>
ko.components.register("sidebar-step", {
    synchronous: true,
    viewModel: function (params) {
        this.vm = params.vm;
    },

    template: "<li data-bind='text: vm.message'>vm.onChangeElement</li>"
});

// model
var SidebarStepModel = function () {
    this.message = ko.observable("step description");
};

// viewmodel
var OrderGuideViewModel = function () {

    this.sidebarStepModel0 = new SidebarStepModel();
    this.sidebarStepModel0.message("step 1");

    this.sidebarStepModel1 = new SidebarStepModel();
    this.sidebarStepModel1.message("step 2");

    this.sidebarStepModel2 = new SidebarStepModel();
    this.sidebarStepModel2.message("step 3");
};

ko.applyBindings(new OrderGuideViewModel());
4

1 回答 1

1

您只需要使用html绑定而不是text绑定:

template: "<li data-bind='html: vm.message'>vm.onChangeElement</li>"

更新的小提琴

于 2015-06-16T21:20:02.280 回答