我第一次尝试使用array_multisort函数,但它没有像我预期的那样工作。我真的希望有人能帮我。我的问题是:
我确实有一个7列的表。我想通过点击列名对其中的4个进行排序。我的问题是,排序过程总是只适用于一个列。让我解释一下我的意思。以下是我想要排序的4列:
Points | Name | Leader | Owner
10 | Chris | Thomas | Philip
0 | Alex | Sandy | Oscar
5 | David | Lucas | Kathi
现在用我的代码,当我点击"Name"的例子,比我的表将排序如下:
Points | Name | Leader | Owner
10 | Alex | Thomas | Philip
0 | Chris | Sandy | Oscar
5 | David | Lucas | Kathi
例如,当我点击"Owner"时,我的表看起来是这样的:
Points | Name | Leader | Owner
10 | Chris | Thomas | Kathi
0 | Alex | Sandy | Oscar
5 | David | Lucas | Philip
因此,正如您所看到的,只有我单击的列将按字母顺序排序,而不是整个表。那不是我需要的。
整个表应该排序,所以作为一个例子,它应该看起来像这样。当我点击"Leader"时,完整的表应该像这样排序:
Points | Name | Leader | Owner
5 | David | Lucas | Kathi
0 | Alex | Sandy | Oscar
10 | Chris | Thomas | Philip
这是我的代码。注意:一切都工作得很好,它只是我的完整代码的一部分,但我希望有人能告诉我我到底做错了什么,我的代码应该是什么样子,这样完整的表将被排序。
<form name='form1' action='./index.php' method='post'>
<input type='hidden' name='func' value='".$func."'>
<input type='hidden' name='submenu' value='".$submenu."'>
<input type='hidden' name='id' value='".$id."'>
<input type='hidden' name='module_id' value='".$module_id."'>
<input type='hidden' name='save_data' value='true'>
<input type='hidden' name='sort' value='".$sort."'>
<input type='hidden' name='sid' value='".$sid."'>
<br><table>
<tr>
<td>P</td>
<td>L</td>
<td>E</td>
<td>O</td>
<td><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=attendance_points&sid=$sid'>Points</a></td>
<td><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=student_name&sid=$sid'>Student</a></td>
<td><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=leader_name&sid=$sid'>Leader</a> | <a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=owner_name&sid=$sid'>Owner</a></td>
</tr>
<?php
$output=array();
if ($sort=="") { $sort="student_name"; }
array_multisort($output[$sort], SORT_ASC, SORT_STRING);
for ($x=0;$x<count($output["id"]);$x++) {
$attendance=getUserModuleAttendanceInfo($output["pers_id"][$x],$id,$module_id);
print "<tr>";
if (count($attendance["id"])==0) {
print "<td align='center'><input type='checkbox' name='part_1_".$output["pers_id"][$x]."' value='1'></td>";
print "<td align='center'><input type='checkbox' name='part_2_".$output["pers_id"][$x]."' value='1'></td>";
print "<td align='center'><input type='checkbox' name='part_3_".$output["pers_id"][$x]."' value='1'></td>";
print "<td align='center'><input type='checkbox' name='part_4_".$output["pers_id"][$x]."' value='1'></td>";
if($output["edit_coursepoints"][$x]==0) {
print "<td align='center'><input type='hidden' name='points_".$output["pers_id"][$x]."' id='spinner_".$output["pers_id"][$x]."' value='".$module["points_present"][0]."'></td>";
}
else {
print "<td align='center'><input type='text' name='points_".$output["pers_id"][$x]."' id='spinner_".$output["pers_id"][$x]."' value='".$module["points_present"][0]."'></td>";
}
$controller_list.="spinner_".$output["pers_id"][$x].";";
} else {
print "<td colspan='4' valign='center' align='center'><span class='label label-".$course_part_state["style"][$attendance["part_state"][0]]."'><i class='ace-icon fa fa-".$course_part_state["icon"][$attendance["part_state"][0]]." bigger-120'></i> ".strtoupper($course_part_state["txt"][$attendance["part_state"][0]])."</span></td>";
print "<td align='center'>".$attendance["part_points"][0]."</td>";
}
print "<td>".$staffshort[$student["grade"][0]]." ".$output["student_name"][$x]."</td>";
print "<td>leader: ".$staffshort[$leader["grade"][0]]." ".$output["leader_name"][$x]."<br>owner: ".$staffshort[$owner["grade"][0]]." ".$output["owner_name"][$x]."</td>";
if (count($attendance["id"])>0) {
print "<td align='center'><a href='./index.php?func=$func&submenu=$submenu&id=$id&module_id=$module_id&sort=$sort&undo=".$attendance["id"][0]."&sid=$sid'><i class='ace-icon fa fa-undo dark bigger-180'></i></a></td>";
}
print "</tr>";
}
?>
希望有人能告诉我我做错了什么!
我建议重新组织你的$output
。现在,每个字段都有一个单独的数组。这很难处理。
如果$output
中的每一行都是具有自己的键/值对的表行,则会更容易。
那么,试着像这样构建它:
$output[] = array(
"id" => $data["id"][$x],
"pers_id" => $student["pers_id"][0],
"student_name" => $student["firstname"][0]." ".strtoupper($student["lastname"][0]),
"owner" => $owner["pers_id"][0],
"owner_name" => $owner["firstname"][0]." ".strtoupper($owner["lastname"][0]),
"leader" => $leader["pers_id"][0],
"leader_name" => $leader["firstname"][0]." ".strtoupper($leader["lastname"][0]),
"edit_coursepoints" => $editcoursepoints,
"attendance_points" => $attendance["part_points"][0]
);
然后你可以用usort
:
usort($output, function($a, $b) use($sort){
return strcmp($a[$sort], $b[$sort]);
});
然后,当您构建表时,只需循环$output
中的每一行并打印出值。
foreach($output as $row){
echo '<tr>';
echo "<td align='center'><input type='checkbox' name='part_1_".$row["pers_id"]."' value='1'></td>";
echo '</tr>';
}