Попытка отсортировать список, используя bootstrap и js - PullRequest
0 голосов
/ 29 мая 2019

Вот изображение таблицы, которую я получаю

Я пытаюсь упорядочить список с именами пациентов, которые я получаю из базы данных примера.Я работал над этим, по крайней мере, 10 часов, теперь я действительно разочарован.я нашел пример кода w3c для сортировки данных таблицы, он работает, когда я использую их примеры, но не когда я включаю мои.

Я в основном все пробовал.JavaScript работает в моем проекте

<!DOCTYPE html>
<html lang="en">

<head>



    <title>Welcome to the Template-Engine</title>
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <#include "header.ftl">
        <!-- common properties are put in one single header file -->


     <style>
table {
  border-spacing: 0;
  width: 100%;
  border: 1px solid #ddd;
}

th {
  cursor: pointer;
}

th, td {
  text-align: left;
  padding: 16px;
}

tr:nth-child(even) {
  background-color: #f2f2f2
}
</style>

</head>

<body class="htwg">



        <h1>Welcome to 0000 FHIR</h1>
        <h2>Searching for Patients</h2>
        <p>Using FHIR ${p_repo} - corresponding information at ${p_info}</p>
        <p>Overall Number of patients: ${p_total}</p>



        <div> 

            <fieldset>

                <legend>Patient suchen</legend>
                    <form action="/patient2/addPatient" method="POST">
                        <div class="form-group">

                            Vorname: <input type="text" name="vorname" placeholder="Vorname" class="form-control" /> <br/>
                            Nachname: <input type="text" name="nachname" placeholder="Nachname" class="form-control" /> <br/>
                            Geburtsdatum: <input type="date" name="date" placeholder="..." class="form-control" />  <br/>
                            <input type="submit" value="Suchen" class="btn btn-secondary btn-lg"/>
                        </div>


                    </form>
            </fliedset>

            </div>






        <table class="js-sort-table" id="myTable" data-sort-order="desc">
            <thead>

                 <tr>
                     <th scope="col" onclick="sortTable(0)">ID</th>
                    <th scope="col" onclick="sortTable(1)">Name</th>
                    <th scope="col" onclick="sortTable(2)">Gender</th>
                    <th scope="col onclick="sortTable(3)">Birthdate</th>

                </tr>

            </thead>
            <tbody>
          <!-- Liste, mit den Suchkriterien, alle 3 müssen eingegeben sein (Keines darf NULL sein)-->
                <#list patientList as p>


                    <tr>
                        <th scope="col" onclick="sortTable(0)" >${(p.id)!"NA"}</th>
                        <th scope="col" onclick="sortTable(1)" >${(p.name)!"NA"}</th>
                        <th scope="col" onclick="sortTable(2)" >${(p.gender)!"NA"}</th>
                        <th scope="col" onclick="sortTable(3)" >${(p.birthdate)!"NA"}</th>

                    </tr>

                </#list>


            </tbody>
        </table>


    </div>
    <script>
function sortTable(n) {
  var table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0;
  table = document.getElementById("myTable");
  switching = true;
  //Set the sorting direction to ascending:
  dir = "asc"; 
  /*Make a loop that will continue until
  no switching has been done:*/
  while (switching) {
    //start by saying: no switching is done:
    switching = false;
    rows = table.rows;
    /*Loop through all table rows (except the
    first, which contains table headers):*/
    for (i = 1; i < (rows.length - 1); i++) {
      //start by saying there should be no switching:
      shouldSwitch = false;
      /*Get the two elements you want to compare,
      one from current row and one from the next:*/
      x = rows[i].getElementsByTagName("TD")[n];
      y = rows[i + 1].getElementsByTagName("TD")[n];
      /*check if the two rows should switch place,
      based on the direction, asc or desc:*/
      if (dir == "asc") {
        if (x.innerHTML.toLowerCase() > y.innerHTML.toLowerCase()) {
          //if so, mark as a switch and break the loop:
          shouldSwitch= true;
          break;
        }
      } else if (dir == "desc") {
        if (x.innerHTML.toLowerCase() < y.innerHTML.toLowerCase()) {
          //if so, mark as a switch and break the loop:
          shouldSwitch = true;
          break;
        }
      }
    }
    if (shouldSwitch) {
      /*If a switch has been marked, make the switch
      and mark that a switch has been done:*/
      rows[i].parentNode.insertBefore(rows[i + 1], rows[i]);
      switching = true;
      //Each time a switch is done, increase this count by 1:
      switchcount ++;      
    } else {
      /*If no switching has been done AND the direction is "asc",
      set the direction to "desc" and run the while loop again.*/
      if (switchcount == 0 && dir == "asc") {
        dir = "desc";
        switching = true;
      }
    }
  }
}
</script>



</body>

</html>

это звучит глупо, но я должен сделать это для Uni, и я действительно на грани плакать.

1 Ответ

0 голосов
/ 29 мая 2019

Иногда даже маленькие опечатки вызывают большие проблемы. Посмотрите на 4-й столб в заголовке таблицы #myTable. Должно быть scope = "col"

Не звучит глупо, мы все были там! Надеюсь это поможет. Удачи.

...