array_multisort -不排序我的完整表


array_multisort - Does not sort my complete table

我第一次尝试使用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>';
}