Вот изображение таблицы, которую я получаю
Я пытаюсь упорядочить список с именами пациентов, которые я получаю из базы данных примера.Я работал над этим, по крайней мере, 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, и я действительно на грани плакать.