在弹出窗口中编辑数据时,仅显示knockoutjs中所有行的第一行数据

时间:2017-04-25 17:44:19

标签: jquery knockout.js bootstrap-modal

我使用knockoutjs使用foreach循环在表格中显示多条记录,在用户点击行编辑时,在我们软件的先前版本中,它显示了tr中的输入字段,以便用户可以编辑。现在我的任务是在用户单击特定tr的用户名时在bootstrap弹出窗口中显示输入字段。 问题是当我点击任何一行时,它只在模态弹出窗口中显示第一行的数据。 以下是我的完整页面代码

<div class="hidden cstm-right-sc" data-bind="css: { hidden: false }" id="AdminPanel">
<div id="CriteriaPanel" class="criteria">
    <div class="criteria_filter">
        <h3>Filter Criteria</h3>
        <div class="filter-criteria_innr">
            <label for="Company">Company</label>
            <select autofocus="autofocus" data-bind="options: Companies, optionsCaption: '(Select)', optionsText: 'Name', optionsValue: 'Id', value: CompanyId, visible: !Busy()" id="Company"></select>
            <span data-bind="visible: Busy"><i class="fa fa-spinner fa-spin"></i> loading...</span>
        </div>
    </div>
</div>
<div id="CriteriaSummaryPanel" class="criteria cstm_sctn">
    <div class="criteria_innr">
        <h3>Community Resident Portal - Client Administrators</h3>

        <div class="criteria_contnt">
            <div data-bind="if: CompanyId()">
                <div data-bind="text: 'Company: ' + CompanyName()"></div>
            </div>
        </div>
    </div>
</div>
<table class="report-table" data-bind="if: CompanyId()">
    <thead>
        <tr>
            <th>
                Login
            </th>
            <th>
                Email
            </th>
            <!-- ko if: $root.EditId() !== null -->
            <!--<th>
                New Password
            </th>
            <th>
                Active
            </th>
            <th>
            </th>-->
            <!-- /ko -->
        </tr>
    </thead>
    <tbody data-bind="foreach: Users">
        <tr>
            <!-- ko if: $root.EditId() === Id() -->
            <td><span data-bind="click: $root.Edit, text: LoginName, css: { clickable: $root.EditId() === null }" data-toggle="modal" data-target="#myModal"></span></td>
            <td>
                <span data-bind="text: EditEmail" />
            </td>

            <!--<td>
                <input data-bind="value: Password, valueUpdate: 'keyup'" type="text" />
            </td>
            <td>
                <input data-bind="checked: IsApproved, visible: $root.EditId() !== 0" type="checkbox" />
                <span data-bind="visible: $root.EditId() === 0">N/A</span>
            </td>
            <td>
                <div id="InlineEditActionPanel">
                    <span data-bind="click: $root.Save, css: { clickable: $root.IsValid }">Save</span>
                    <span class="clickable" data-bind="click: $root.CancelEdit">Cancel</span>
                </div>
            </td>-->
            <!-- /ko -->
            <!-- ko ifnot: $root.EditId() === Id() -->
            <td><span data-bind="click: $root.Edit, text: LoginName, css: { clickable: $root.EditId() === null }" data-toggle="modal" data-target="#myModal"></span></td>
            <td data-bind="text: Email"></td>
            <!-- ko if: $root.EditId() === 0 -->
            <!--<td></td>
            <td></td>
            <td></td>-->
            <!-- /ko -->
            <!-- /ko -->
        </tr>
        <tr class="modal fade" id="myModal" role="dialog" tabindex="-1">
            <td colspan="3" class="modal-dialog" role="document">
                <div class="modal-header">
                    <button type="button" class="close" data-dismiss="modal">&times;</button>
                    <h4 class="modal-title">Client Admins</h4>
                </div>
                <div class="modal-content">
                    <div>
                        <input data-bind="visible: Id() === 0, value: LoginName, valueUpdate: 'keyup'" type="text">
                        <span data-bind="visible: Id() !== 0, text: LoginName" style="display: none;"></span>

                    </div>
                    <div>
                        <input data-bind="value: EditEmail, valueUpdate: 'keyup'" type="text">
                    </div>

                    <div>
                        <input data-bind="value: Password, valueUpdate: 'keyup'" type="text">
                    </div>
                    <div>
                        <input data-bind="checked: IsApproved, visible: $root.EditId() !== 0" style="display: none;" type="checkbox">
                        <span data-bind="visible: $root.EditId() === 0">N/A</span>

                    </div>
                    <div>
                        <div id="InlineEditActionPanel">
                            <span data-bind="click: $root.Save, css: { clickable: $root.IsValid }">Save</span>
                            <span class="clickable" data-bind="click: $root.CancelEdit" data-dismiss="modal">Cancel</span>
                        </div>
                    </div>
                </div>
            </td>
        </tr>
    </tbody>
    <tfoot>
        <tr>
            <td data-bind="attr: { colspan: $root.EditId() === null ? 4 : 5 }">
                <span data-bind="click: $root.Add, css: { clickable: $root.EditId() === null }" data-toggle="modal" data-target="#myModal2">Add new user</span>
            </td>
        </tr>
        <tr class="modal fade" id="myModal2" role="dialog" tabindex="-1">
            <td colspan="3" class="modal-dialog" role="document">
                <div class="modal-header">
                    <button type="button" class="close" data-dismiss="modal">&times;</button>
                    <h4 class="modal-title">Client Admins</h4>
                </div>
                <div class="modal-content">
                    <div>
                        <input data-bind="visible: Id() === 0, value: LoginName, valueUpdate: 'keyup'" type="text">
                        <span data-bind="visible: Id() !== 0, text: LoginName" style="display: none;"></span>

                    </div>
                    <div>
                        <input data-bind="value: EditEmail, valueUpdate: 'keyup'" type="text">
                    </div>

                    <div>
                        <input data-bind="value: Password, valueUpdate: 'keyup'" type="text">
                    </div>
                    <div>
                        <input data-bind="checked: IsApproved, visible: $root.EditId() !== 0" style="display: none;" type="checkbox">
                        <span data-bind="visible: $root.EditId() === 0">N/A</span>

                    </div>
                    <div>
                        <div id="InlineEditActionPanel">
                            <span data-bind="click: $root.Save, css: { clickable: $root.IsValid }">Save</span>
                            <span class="clickable" data-bind="click: $root.CancelEdit">Cancel</span>
                        </div>
                    </div>
                </div>
            </td>
        </tr>
    </tfoot>
</table>

请帮助我,我是淘汰赛的新手。 这非常重要。

1 个答案:

答案 0 :(得分:1)

您在myModal内多次创建ID为foreach: Users的模式,因此您有多个具有相同ID的模态。它打开了第一个使用该ID找到的模态,这是第一个记录。您需要唯一地命名模态,例如

<td>
    <span data-bind="click: $root.Edit, text: LoginName,
          css: { clickable: $root.EditId() === null },
          attr: {'data-target', '#myModal' + Id()}"
          data-toggle="modal"></span>
</td>

<tr class="modal fade" data-bind="attr: { id: 'myModal' + Id()}"
    role="dialog" tabindex="-1">