jquery - 使用 json 对象重新加载 bootstrap-table 中的数据

标签 jquery json ajax twitter-bootstrap bootstrap-table

我用 bootstrap 制作了一个网站。我有一个 Bootstrap 表,最初它是从包含 php 代码加载的。这工作正常,没有问题。

之后,我有一个按钮,当单击它时,它会打开一个窗口模式来选择不同的参数来发送查询。我使用 jquery 和 ajax 将变量 POST 到另一个 php,并得到一个 json 对象,如下所示:

{
  "estado":"PE",
  "id_usuario":"20",
  "nombre":"Irene",
  "apellido1":"Munn\u00e9",
  "id_addtime_horario":"7",
  "fecha":"2016-12-30",
  "dia_semana":"friday   ",
  "hora_ini":"10:00:00",
  "hora_fin":"15:09:26",
  "jornada":"05:42:12",
  "jornada_flexibilidad":"00:02:46",
  "jornada_deficit":"00:00:00",
  "extra_jornada":"00:00:00",
  "extra_autorizado":null,
  "id_fichaje":"1766",
  "id_fichaje_detalle":"44071"
}

问题是我无法使用该数组加载 Bootstrap 表。

我在互联网上和这里也阅读了很多内容。我尝试制作一个小型 Bootstrap 表和小型查询来丢弃代码减法中的错误,但它无法正常工作。它总是获取 json 对象,但它不会加载到 Bootstrap 表中。

我使用此 jquery 代码将参数通过 post 发送到 php 代码,并使用此参数获取 json 对象:

  /*  QUERY   */

      $('#executaquery').on('click', function(){

          //  Recupero valors per POST to php

          var usuari = document.getElementById('usuari').value;
          var estat = document.getElementById('estat').value;
          var data_in = document.getElementById('data_in').value;
          var data_fi = document.getElementById('data_fi').value;

      $.ajax({                                                              // Llamada a queryProduct.php devuelve objeto array JSON asigno a
         method: 'POST',                                                      // los campos de modal window
         dataType: 'json',
         url: 'queryFitxatges.php',
         data: { usuaris: usuari, estats: estat, datain: data_in, datafi: data_fi},

         success: function(response) {

            $('#consulta').modal('hide');

            var myData = [];
            myData.push(response);

            $('#tableprod').bootstrapTable('load', myData);
         }
      });
  });

我已阅读将 json 对象与 bootstrap-table 的字段链接起来,只有 bootstrap-table 的数据字段参数必须与 json 对象相同:

  <thead class='thead-inverse'>
                  <tr>
                      <th data-switchable='false' data-checkbox='true'></th>
                      <th data-field='estado' data-sortable='true'><?php echo $cols[0]; ?></th>
                      <th data-field='id_usuario' data-sortable='true'><?php echo $cols[1]; ?></th>
                      <th data-field='nombre' data-sortable='true'><?php echo $cols[2]; ?></th>
                      <th data-field='apellido1' data-sortable='true'><?php echo $cols[3]; ?></th>
                      <th data-field='id_addtime_horario' data-sortable='true'><?php echo $cols[4]; ?></th>
                      <th data-field='fecha' data-sortable='true'><?php echo $cols[5]; ?></th>
                      <th data-field='dia_semana' data-sortable='true'><?php echo $cols[6]; ?></th>
                      <th data-field='hora_ini' data-sortable='true'><?php echo $cols[7]; ?></th>
                      <th data-field='hora_fin' data-sortable='true'><?php echo $cols[8]; ?></th>
                      <th data-field='jornada' data-sortable='true'><?php echo $cols[9]; ?></th>
                      <th data-field='jornada_flexibilidad' data-sortable='true'><?php echo $cols[10]; ?></th>
                      <th data-field='jornada_deficit' data-sortable='true'><?php echo $cols[11]; ?></th>
                      <th data-field='extra_jornada' data-sortable='true'><?php echo $cols[12]; ?></th>
                      <th data-field='extra_autoritzado' data-sortable='true'><?php echo $cols[13]; ?></th>
                      <th data-field='edit' data-sortable='false' data-switchable='false'>EDIT</th>
                    </tr>
              </thead>
              <tbody>
            <?php while ($row = pg_fetch_row($result)){ ?>
                  <tr id='<?php echo $row[14]; ?>' data-idfixatgedetall='<?php echo $row[15]; ?>' data-estado='<?php echo $row[0] ?>' data-autoritzat='<?php echo $autoritzat = $row[12]; ?>'>
                      <td></td>
                      <td data-field='estado'><?php echo $estado = EstadoIcon($row[0]); ?></td>
                      <td data-field='id_usuario'><?php echo $row[1]; ?></td>
                      <td data-field='nombre'><?php echo $row[2]; ?></td>
                      <td data-field='apellido1'><?php echo $row[3]; ?></td>
                      <td data-field='id_addtime_horario'><?php echo $row[4]; ?></td>
                      <td data-field='fecha'><?php echo $date = FormatDate($row[5]); ?></td>
                      <td data-field='dia_semana'><?php echo $dia = Dia($row[6]); ?></td>
                      <td data-field='hora_ini'><?php echo $time = FormatTime24($row[7]); ?></td>
                      <td data-field='hora_fin'><?php echo $time = FormatTime24($row[8]); ?></td>
                      <td data-field='jornada'><?php echo $time = FormatTime($row[9]); ?></td>
                      <td data-field='jornada_flexibilidad'><?php echo $time = FormatTime($row[10]); ?></td>
                      <td data-field='jornada_deficit'><?php echo $time = FormatTime($row[11]); ?></td>
                      <td data-field='extra_jornada'><?php echo $time = FormatTime($row[12]); ?></td>
                      <td data-field='extra_autoritzat'><?php echo $autoritzat = Autoritzat($row[13]); ?></td>
                      <td><button class='btn btn-xs edit btn-addcom' data-toggle='modal' data-target='#edit'><i class="material-icons" style="font-size: 20px">edit</i> </button></td>
                  </tr>
            <?php }  ?>
              </tbody>
            </table>

我尝试使用参数“load”和“append”加载数据,但结果相同。

任何人都可以帮助我理解如何将 json 对象与 bootstrap-table 的字段链接起来?是否有可能错误是第一次数据加载使用php?

最佳答案

谢谢!我一直在努力使用 ajax 刷新 Bootstrap 表(在 Ruby on Rails 应用程序中)。不知道:

$('#tableprod').bootstrapTable('load', myData);

在我的ajax函数中使用这个:

$('#tableprod').bootstrapTable({ data: data });

它第一次填充表格,但是当我从下拉选择中再次调用该 ajax 函数时,它不会刷新。

刚刚发现:如果我的 ajax 函数中有这个,它会刷新表格:

$('#taggedStudyTable').bootstrapTable({ data: data });
$('#taggedStudyTable').bootstrapTable('load', data);

很欣慰地在你的例子中看到这一点,尝试一下,看看它是否有效。 (谢谢!)

关于jquery - 使用 json 对象重新加载 bootstrap-table 中的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41471423/

相关文章:

jquery - jQuery 的 space 和 > 选择器有什么区别?

ios - 下载JSON数据,然后重新加载 Collection View

javascript - jQuery 加载动态内容并使其可通过 url 进行访问

json - Redis/Rejson 嵌套文档层次结构性能

c++ - 使用 casablanca 解析 JSON 数组

javascript - 在基于 ajax 的网站的动态加载内容上运行 javascript

ajax - 是否有任何框架支持 Websocket 并在客户端浏览器不支持时回退到其他方法?

jquery - 扩展 jQuery 验证密码功能

javascript - 是否可以在使用 javascript 延迟的页面中拼出一个单词?

jquery - 设置可编辑字段和不可编辑字段的选项卡