簡體   English   中英

根據訂單類型添加上下箭頭

[英]Adding Up and Down Arrows according to Order Type

我正在通過ajax和PHP從數據庫中獲取數據,返回的數據顯示為表格,我創建了一個對表格列的升序或降序進行排序的函數,我想在列名旁邊添加箭頭以在ascending order情況下顯示&如果descending order ,該怎么辦?

HTML代碼

<head>
  <link rel="stylesheet" href="../lib/css/bootstrap.min.css" type="text/css"/>
  <script src="https://use.fontawesome.com/d7a6f6be38.js"></script>
  <script type="text/javascript" src="../lib/js/jquery-3.1.1.min.js"></script>
  <link href="//cdn.datatables.net/1.10.16/css/jquery.dataTables.min.css" rel="stylesheet"/>
  <script src="//cdn.datatables.net/1.10.16/js/jquery.dataTables.min.js"></script>
</head>
<div class="row">
   <div id="OrderTable"></div>
</div>

PHP頁面searchorders.php

<?php
 $output.='<hr />
  <table id="SearchResults" class="table table-striped table-bordered" style="width:auto;">
    <thead>
    <tr>
        <th>Order No.</th>
        <th>Customer Name</th>
        <th>Order Date</th>
        <th>Category Name</th>
        <th>Category Type</th>
        <th>Quantity in Kilos</th>
        <th>Delivery Date</th>
        <th>Order Status</th>
    </tr>
    </thead>
 ';

 echo $output;
?>

Javascript功能

function SearchOrders()
{
    document.getElementById("OrderTable").innerHTML="";
    document.getElementById("NoData").innerHTML="";
    document.getElementById("Results").style.display = 'none';

    startDate=document.getElementById("Start_Date").value;
    endDate=document.getElementById("End_Date").value;

    $.ajax({
        type:"POST",
        url:"searchorders.php",
        data:
            { 
               'StartDate': startDate, 
               'EndDate':endDate
            },
        success: function(data)
        {
            if (data == "Failed")
            {
                $('#NoData').append("No data Found!");
            }
            else
            {
                $('#OrderTable').append(data);
                document.getElementById("Results").style.display = 'block';

                $('#SearchResults').DataTable({"columnDefs": [ {
                               "targets": [0,4,5,6],
                                "orderable": false
                              }]});
            }
        }
    })
}

首先添加向上(向上)和向下(向下)箭頭。 我在這里使用span內的文本,您可以將其替換為圖標或其他內容,但將其id保持不變。

<th onclick="sortTable(1)">
  <span id="asc1">Up</span>
  <span id="desc1">Down</span>
  Customer Name
</th>
<th onclick="sortTable(2)">
  <span id="asc2">Up</span>
  <span id="desc2">Down</span>
  Order Date
</th>
<th onclick="sortTable(3)">
  <span id="asc3">Up</span>
  <span id="desc3">Down</span>
  Category Name
</th>

然后將它們隱藏在CSS中,並根據自己的喜好對其進行樣式設置

th>span{
  display:none;
}

然后編寫jquery代碼,因為您正在將n傳遞給函數,並且您也知道排序的方向。 因此,只需對ID進行反向工程並顯示該箭頭即可。

$('th>span').hide();
var idChange = '#'+ dir + n;
$(idChange).show();

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM