无法通过JavaScript添加按钮来渲染KO模板数据

时间:2013-08-14 19:41:41

标签: javascript knockout.js twig knockout-2.0 knockout-mvc

如果标题有误导性,我提前道歉。我整天都在处理这个问题,我想知道是否有人可以提供帮助。

概述: 我们所有的模板都预先加载到DOM中。以前,所有表单(模板)都设计为在现有页面上显示。但是,我们最近移动了所有模板以在jQueryUI对话框中显示。我已经成功地移动了所有必要的代码来使这个工作除了一个模板,我相信这是因为在进行搜索后,用模板打开jQueryUI对话框的按钮被加载到DOM中。

“添加”按钮调用ViewModel中的“addUos”函数,以便用户可以继续添加任意数量的表单。

HTML

模板:(使用TWIG作为模板引擎)

<script type="text/html" id="adduos-form">
    {% include "sections/adduos.html" %}
</script>

jQueryUi对话:

<div id="addUosDialog" title="Add UOS (Units of Service)">
<div id="addUosDialogDiv">
    <div id="adduos_block">
        <form id="adduosForm" action="" method="">
            <div id="addUosDiv">
                <!-- Populated by Ajax via clientTabs.js -->
            </div>
        </form>
    </div>
</div>

JavaScript的:

此代码创建模板将在

中呈现的div
var currDialogDiv = $("#addUosDiv");
var currDialogForm = $("<div id='addUosForm' data-bind=\"" + "template: { name:'adduos-form', foreach: uos_data }\"></div>");

//Create Template
$(currDialogDiv).append(currDialogForm);

此代码位于for循环中,并在基本网格中创建所有用户条目。将为每个条目创建“添加和编辑”按钮。 “编辑”按钮工作正常,但“添加”按钮将根据需要打开“对话框”,但不会显示模板。在使用Chrome Dev Tools进行测试后,VM中的addUos功能不会在点击时触发。 (这是我的主要问题)

$(currTR).append("<td class='bodyId'>" + currRegNo + "</td>"); //TODO: This will be removed in the future
$(currTR).append("<td>" + currLastName + "</td>");
$(currTR).append("<td>" + currFirstName + "</td>");
$(currTR).append("<td>" + currDob + "</td>");
$(currTR).append("<td>" + currType + "</td>");
$(currTR).append("<td><a href='javascript:;' data-bind='click: $root.addUos' onclick='openAddUosDialog(" + currRegId + ", \"" + currFirstName + "\", \"" + currLastName + "\")' class='button blue small'>Add</a><a href='javascript:;' onclick='openEditUosDialog(" + currRegId + ")' class='button blue small'>Edit</a></td>");

然后我将绑定应用于特定元素

ko.applyBindings(viewModelObj.clientsUosVM, document.getElementById("addUosForm"));

ViewModelObj :(我目前有2个独立的虚拟机)

viewModelObj = {

    clientsVM : new clientsVM(),
    clientsUosVM : new clientsUosVM()
};

ko.applyBindings(viewModelObj.clientsVM);
clientsUosVM = new clientsUosVM();

视图模型:

function clientsUosVM() {

var self = this;
var uCount = 0; //UOS Forms

self.uos_data = ko.observableArray();

self.addUos = function() {

    self.uos_data.push({
        uosloc : 'uos[' + uCount + '][uosloc]',
        uosloc_id : 'uosloc_' + uCount,

        uossrv : 'uos[' + uCount + '][uossrv]',
        uossrv_id : 'uossrv_' + uCount,

        uosnum : 'uos[' + uCount + '][uosnum]',
        uosnum_id : 'uosnum_' + uCount,

        uosbegin : 'uos[' + uCount + '][uosbegin]',
        uosbegin_id : 'uosbegin_' + uCount,

        uosexp : 'uos[' + uCount + '][uosexp]',
        uosexp_id : 'uosexp_' + uCount
    });

    populateLoc($('select#uosloc_' + uCount));
    $('input#uosbegin_' + uCount).mask('99/99/2099');
    $('input#uosexp_' + uCount).mask('99/99/2099');
    uCount++;
};

self.removeUos = function(item) {

    self.uos_data.remove(item);
};

self.dumpUos = function() {

    self.uos_data([]);
};
}

我包含了我认为是一个因素的所有代码,但如果您需要任何其他信息或代码,请告诉我。提前谢谢!

1 个答案:

答案 0 :(得分:0)

感谢无论是谁花时间阅读我的长篇问题,但我在离开工作之前昨天发现了我的问题。

我刚删除了数据绑定点击事件data-bind='click: $root.addUos并将其移至onclick函数'openAddUosDialog()'

希望这有助于其他人遇到类似的问题。

//Open Add UOS Dialog
function openAddUosDialog(regid, fname, lname) {

viewModelObj.clientsUosVM.dumpUos();
viewModelObj.clientsUosVM.addUos();
$("#adduos_block").show(200);

//Open Dialog
$("#addUosDialog").dialog("open");

$("#auos_regid").val(regid);
$("#auos_fname").val(fname);
$("#auos_lname").val(lname);
}