javascript - 在 foreach 内创建动态属性时出现问题 : knockoutjs

标签 javascript knockout.js

我在 Accordion 中显示数据时遇到问题,如图所示。

无论单击哪一行,都会显示相同的“隐藏行”。我明白为什么......下面的行设置了 Accordion 元素的目标。

<tr data-toggle="collapse" data-target="#demo1"  class="accordion-toggle">

不知何故,我需要使“#demo1”以及隐藏行都独一无二。

下面是代码:我如何确保每一行都有自己唯一的目标 ID 以及隐藏行?

谢谢!

Grid

<table class="table table-striped table-bordered notranslate">
   <thead>
      <tr>
         <th style="width: 10%">ID</th>
         <th>First</th>
         <th>Last</th>
         <th>Email</th>
         <th>Phone</th>
         <th>Actions</th>
      </tr>
   </thead>
   <tbody data-bind="foreach: customers">
      <tr data-toggle="collapse" data-target="#demo1"  class="accordion-toggle">
         <td>
            <i class="fa fa-plus" style="cursor: pointer"></i>
         </td>
         <td data-bind="text: firstName"></td>
         <td data-bind="text: lastName"></td>
         <td data-bind="text: email"></td>
         <td data-bind="text: phone"></td>
         <td>  <i class="fa fa-pencil mr-1" data-bind="click: $root.editCustomer"></i> <i class="fa fa-trash mr-1" data-bind="click: $root.deleteCustomer"></i></td>
      </tr>
      <tr>
         <td colspan="6" class="hiddenRow">
            <div class="accordian-body collapse" id="demo1"  >
               <table class="" style="background-color: lightyellow; width: 100%;">
                  <tbody>
                     <tr>
                        <th>Address 1</th>
                        <th>Address 2</th>
                        <th>City</th>
                        <th>State</th>
                        <th>Zip Code</th>
                     </tr>
                     <tr>
                        <td data-bind="text: address1"></td>
                        <td data-bind="text: address2"></td>
                        <td data-bind="text: city"></td>
                        <td data-bind="text: state"></td>
                        <td data-bind="text: zip"></td>
                     </tr>
               </table>
            </div>
         </td>
      </tr>
   </tbody>
</table>

最佳答案

您应该确保每行的data-target 和匹配的隐藏行id 都是唯一的。您可以使用 attr数据绑定(bind)来动态设置这些属性并利用 foreach$index 上下文可观察属性绑定(bind)以构造唯一的匹配值。

这可能会导致例如数据目标的 data-bind="attr: { 'data-target': '#demo' + $index() }" data-bind="attr: { id: 'demo' + $index() }" 用于匹配的隐藏行 id。看一下下面的简化示例:

ko.applyBindings({
  customers: [{}, {}, {}, {}]
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.4.2/knockout-min.js"></script>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>

<table class="table table-striped table-bordered notranslate">
   <thead>
      <tr>
         <th style="width: 10%">ID</th>
         <th>First</th>
         <th>Last</th>
         <th>Email</th>
         <th>Phone</th>
         <th>Actions</th>
      </tr>
   </thead>
   <tbody data-bind="foreach: customers">
      <tr data-toggle="collapse" data-bind="attr: { 'data-target': '#demo' + $index() }"  class="accordion-toggle">
         <td colspan="6">Click to toggle</td>
      </tr>
      <tr>
         <td colspan="6" class="hiddenRow">
            <div class="accordian-body collapse" data-bind="attr: { id: 'demo' + $index() }">
               <table class="" style="background-color: lightyellow; width: 100%;">
                  <tbody>
                     <tr>
                        <th>Address 1</th>
                        <th>Address 2</th>
                        <th>City</th>
                        <th>State</th>
                        <th>Zip Code</th>
                     </tr>
                     <tr>
                        <td colspan="5">...</td>
                     </tr>
               </table>
            </div>
         </td>
      </tr>
   </tbody>
</table>

关于javascript - 在 foreach 内创建动态属性时出现问题 : knockoutjs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58125159/

相关文章:

javascript - 如何使用 ko.mapping.fromJS 用来自 Ajax 调用的数据填充 observableArray?

javascript - 在 foreach 列表之后运行脚本

javascript - knockout 和切换开关 - 数据绑定(bind)

javascript - 可以将依赖跟踪与 knockout js 中的行为分开吗?

Javascript 函数 Object.keys 无法正常工作

javascript - 保存、显示和删除 json 文件

javascript - SweetAlert 使用@Html.ActionLink 确认提示

javascript - 如何从每个绑定(bind)内部的 Oracle jet 下拉列表中唯一标识所选值

javascript - ES6 对象数组上的展开语法,以及获取对象属性

javascript - 如何在 jquery 中将 img src 设置为 php session