如何隐藏代码为“。”的数据表行例如通过jQuery 1.1、1.2?

时间:2018-08-08 06:53:23

标签: javascript php jquery mysql web

我通过ajax将两个输入的数据带到另一页。我在查询中使用了这两个值,并在数据表中显示了选择查询的结果,该数据表返回到成功函数并显示在主页上的表中。

在那之后,我想使用一个条件,除非他单击按钮,否则隐藏"." (accounting->subaccounts)的数据。

我只需要隐藏一个主意就可以做更多的事情。让我告诉你我的代码。

这是按钮:

<input type="button" id="generate" onclick="getData();" value="Generate"  
class="btn btn-block btn-primary btn-sm" />

我在其中显示表格的div:

<div class="col-lg-12 col-sm-12 col-xs-12 col-md-12" id="tab"></div>

ajax函数:

function getData() {
            var date = $("#date").val();
            var classId = $("#class").val();
            $.ajax({
                url: "ajax/getTrailBalanceData.php",
                type: "POST",
                data: {
                    "date": date,
                    "classId": classId,
                },
                cache: false,
                async: false,
                success: function (data) {
        //alert(data);                  
                    $("#tab").html(data);

                    var row_main_code = $("#main_code").val();


                    if (row_main_code.indexOf(".") > -1) {
    //                  $("#tbl_row").addClass("hide");
                    } else {
  //                      $("#tbl_row").removeClass("hide");
 //                    $("#main_code").parents("tr").hide();
 //                    $("#tbl_row").addClass("hide");
      //                 $("#main_code").val("hide");
                    }
                }
            });
        }

我尝试了“成功”中的if(rowmaincode.indexof('.')>-1)条件,但没有给出令人满意的结果。我很困惑,我不知道为什么,但是让我向您展示其他页面代码:

<table id="trail_balance_list" class="table table-bordered table-condensed bootstrap-datatable datatable responsive">
<thead id="table_head">
    <tr class="bg-success">

        <th class=" text-center">Code</th>
        <th class=" text-center">Account Title</th>
        <th class=" text-center" >Debit</th>
        <th class=" text-center" >Credit</th>
        <th class=" text-center" >Action</th>

    </tr>
</thead>
<tbody>
    <?php
    while ($row = mysqli_fetch_assoc($result)) {
        ?>
    <tr  id="tbl_row" class="">
            <td><?php echo $row['main_code']; ?><input type="hidden" id="main_code" value="<?php echo $row['main_code']; ?>" /></td>
            <td><?php echo $row['account_title']; ?></td>
            <td></td>
            <td></td>
            <td class="text-center"><button class="btn btn-info"><i class="fa fa-arrow-down"></i></button></td>
        </tr>
        <?php
    }
    ?>
</tbody>
<tfoot>
    <tr>
        <th><input type="hidden" id="total_credit_input" name="total_credit" value="0" /></th>
        <th><input type="hidden" id="total_debit_input" name="total_debit" value="0" /></th>
        <td class="bg-warning text-center" id="total_debit">0.00</td>
        <td class="bg-warning text-center" id="total_credit" >0.00</td>

    </tr>
</tfoot>
</table>
<script>
   $(document).ready(function () {
        $("#trail_balance_list").dataTable();
   });
</script>

我得到的结果是:(见图),我只想显示1,2,3,4

i want show only like 1,2,3,4

1 个答案:

答案 0 :(得分:2)

您已经在代码中实现了类似的想法,希望您可以这样做。我在下面添加了一个示例。

$('body').on('click', '#act_button', function() {
  $('#trail_balance_list > tbody  > tr').each(function() {
    if ($(this).find('td:first').text().indexOf('.') >= 0) {
      $(this).hide();
    } else {
      $(this).show();
    }
  });
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<button id="act_button">hide decimal rows</button>
<table id="trail_balance_list" border="1">
  <tbody>
    <tr>
      <td>1</td>
      <td>222</td>
    </tr>
    <tr>
      <td>33.3</td>
      <td>444</td>
    </tr>
    <tr>
      <td>555</td>
      <td>666</td>
    </tr>
    <tr>
      <td>77</td>
      <td>666</td>
    </tr>
  </tbody>
</table>